Search in sources :

Example 31 with EventType

use of com.redhat.cloud.notifications.models.EventType in project notifications-backend by RedHatInsights.

the class LifecycleITest method addEventTypeBehavior.

@Transactional
void addEventTypeBehavior(UUID eventTypeId, UUID behaviorGroupId) {
    EventType eventType = entityManager.find(EventType.class, eventTypeId);
    BehaviorGroup behaviorGroup = entityManager.find(BehaviorGroup.class, behaviorGroupId);
    EventTypeBehavior behavior = new EventTypeBehavior();
    behavior.setId(new EventTypeBehaviorId());
    behavior.setEventType(eventType);
    behavior.setBehaviorGroup(behaviorGroup);
    entityManager.persist(behavior);
}
Also used : EventType(com.redhat.cloud.notifications.models.EventType) BehaviorGroup(com.redhat.cloud.notifications.models.BehaviorGroup) EventTypeBehavior(com.redhat.cloud.notifications.models.EventTypeBehavior) EventTypeBehaviorId(com.redhat.cloud.notifications.models.EventTypeBehaviorId) Transactional(javax.transaction.Transactional)

Example 32 with EventType

use of com.redhat.cloud.notifications.models.EventType in project notifications-backend by RedHatInsights.

the class LifecycleITest method test.

@Test
void test() {
    final String accountId = "tenant";
    final String orgId = "org-id";
    final String username = "user";
    setupEmailMock(accountId, orgId, username);
    // First, we need a bundle, an app and an event type. Let's create them!
    Bundle bundle = resourceHelpers.createBundle(BUNDLE_NAME);
    Application app = resourceHelpers.createApp(bundle.getId(), APP_NAME);
    EventType eventType = resourceHelpers.createEventType(app.getId(), EVENT_TYPE_NAME);
    // We also need behavior groups.
    BehaviorGroup behaviorGroup1 = createBehaviorGroup(accountId, bundle);
    BehaviorGroup behaviorGroup2 = createBehaviorGroup(accountId, bundle);
    BehaviorGroup defaultBehaviorGroup = createBehaviorGroup(null, bundle);
    // We need actions for our behavior groups.
    Endpoint endpoint1 = createWebhookEndpoint(accountId, SECRET_TOKEN);
    Endpoint endpoint2 = createWebhookEndpoint(accountId, SECRET_TOKEN);
    Endpoint endpoint3 = createWebhookEndpoint(accountId, "wrong-secret-token");
    // We'll start with a first behavior group actions configuration. This will slightly change later in the test.
    addBehaviorGroupAction(behaviorGroup1.getId(), endpoint1.getId());
    addBehaviorGroupAction(behaviorGroup1.getId(), endpoint2.getId());
    addBehaviorGroupAction(behaviorGroup2.getId(), endpoint3.getId());
    // Adding an email endpoint to the default behavior group
    addDefaultBehaviorGroupAction(defaultBehaviorGroup);
    // Let's push a first message! It should not trigger any webhook call since we didn't link the event type with any behavior group.
    pushMessage(0, 0, 0, 0);
    // Now we'll link the event type with one behavior group.
    addEventTypeBehavior(eventType.getId(), behaviorGroup1.getId());
    // Get the account canonical email endpoint
    Endpoint emailEndpoint = statelessSessionFactory.withSession(statelessSession -> {
        return getAccountCanonicalEmailEndpoint(accountId);
    });
    // Pushing a new message should trigger two webhook calls.
    pushMessage(2, 0, 0, 0);
    // Let's check the notifications history.
    retry(() -> checkEndpointHistory(endpoint1, 1, true));
    retry(() -> checkEndpointHistory(endpoint2, 1, true));
    retry(() -> checkEndpointHistory(emailEndpoint, 0, true));
    // We'll link the event type with the default behavior group
    addEventTypeBehavior(eventType.getId(), defaultBehaviorGroup.getId());
    // We'll link an additional behavior group to the event type.
    addEventTypeBehavior(eventType.getId(), behaviorGroup2.getId());
    // Pushing a new message should trigger three webhook calls and 1 emails - email is not sent as the user is not subscribed
    pushMessage(3, 1, 0, 0);
    // Let's check the notifications history again.
    retry(() -> checkEndpointHistory(endpoint1, 2, true));
    retry(() -> checkEndpointHistory(endpoint2, 2, true));
    retry(() -> checkEndpointHistory(endpoint3, 1, false));
    retry(() -> checkEndpointHistory(emailEndpoint, 0, true));
    // Lets subscribe the user to the email preferences
    subscribeUserPreferences(accountId, username, app.getId());
    // Pushing a new message should trigger three webhook calls and 1 email
    pushMessage(3, 1, 1, 0);
    // Let's check the notifications history again.
    retry(() -> checkEndpointHistory(endpoint1, 3, true));
    retry(() -> checkEndpointHistory(endpoint2, 3, true));
    retry(() -> checkEndpointHistory(endpoint3, 2, false));
    retry(() -> checkEndpointHistory(emailEndpoint, 1, true));
    /*
         * Let's change the behavior group actions configuration by adding an action to the second behavior group.
         * Endpoint 2 is now an action for both behavior groups, but it should not be notified twice on each message because we don't want duplicate notifications.
         */
    addBehaviorGroupAction(behaviorGroup2.getId(), endpoint2.getId());
    // Pushing a new message should trigger three webhook calls.
    pushMessage(3, 1, 1, 0);
    // Let's check the notifications history again.
    retry(() -> checkEndpointHistory(endpoint1, 4, true));
    retry(() -> checkEndpointHistory(endpoint2, 4, true));
    retry(() -> checkEndpointHistory(endpoint3, 3, false));
    retry(() -> checkEndpointHistory(emailEndpoint, 2, true));
    /*
         * What happens if we unlink the event type from the behavior groups?
         * Pushing a new message should not trigger any webhook call.
         */
    // Unlinking user behavior group
    clearEventTypeBehaviors(eventType);
    pushMessage(0, 0, 0, 0);
    // The notifications history should be exactly the same than last time.
    retry(() -> checkEndpointHistory(endpoint1, 4, true));
    retry(() -> checkEndpointHistory(endpoint2, 4, true));
    retry(() -> checkEndpointHistory(endpoint3, 3, false));
    retry(() -> checkEndpointHistory(emailEndpoint, 2, true));
    // Linking the default behavior group again
    addEventTypeBehavior(eventType.getId(), defaultBehaviorGroup.getId());
    pushMessage(0, 1, 1, 0);
    // Deleting the default behavior group should unlink it
    deleteBehaviorGroup(defaultBehaviorGroup);
    pushMessage(0, 0, 0, 0);
    // We'll finish with a bundle removal.
    deleteBundle(bundle);
}
Also used : Endpoint(com.redhat.cloud.notifications.models.Endpoint) EventType(com.redhat.cloud.notifications.models.EventType) Bundle(com.redhat.cloud.notifications.models.Bundle) BehaviorGroup(com.redhat.cloud.notifications.models.BehaviorGroup) ArgumentMatchers.anyString(org.mockito.ArgumentMatchers.anyString) Application(com.redhat.cloud.notifications.models.Application) Test(org.junit.jupiter.api.Test) QuarkusTest(io.quarkus.test.junit.QuarkusTest)

Example 33 with EventType

use of com.redhat.cloud.notifications.models.EventType in project notifications-backend by RedHatInsights.

the class EmailTemplateMigrationServiceTest method testMigration.

@Test
void testMigration() {
    /*
         * Bundle: rhel
         */
    Bundle rhel = findBundle("rhel");
    // App: advisor
    Application advisor = resourceHelpers.createApp(rhel.getId(), "advisor");
    EventType newRecommendation = resourceHelpers.createEventType(advisor.getId(), "new-recommendation");
    EventType resolvedRecommendation = resourceHelpers.createEventType(advisor.getId(), "resolved-recommendation");
    EventType deactivatedRecommendation = resourceHelpers.createEventType(advisor.getId(), "deactivated-recommendation");
    // App: compliance
    Application compliance = resourceHelpers.createApp(rhel.getId(), "compliance");
    EventType complianceBelowThreshold = resourceHelpers.createEventType(compliance.getId(), "compliance-below-threshold");
    EventType reportUploadFailed = resourceHelpers.createEventType(compliance.getId(), "report-upload-failed");
    // App: drift
    Application drift = resourceHelpers.createApp(rhel.getId(), "drift");
    EventType driftBaselineDetected = resourceHelpers.createEventType(drift.getId(), "drift-baseline-detected");
    // App: edge-management
    Application edgeManagement = resourceHelpers.createApp(rhel.getId(), "edge-management");
    EventType imageCreation = resourceHelpers.createEventType(edgeManagement.getId(), "image-creation");
    EventType updateDevices = resourceHelpers.createEventType(edgeManagement.getId(), "update-devices");
    // App: patch
    Application patch = resourceHelpers.createApp(rhel.getId(), "patch");
    EventType newAdvisories = resourceHelpers.createEventType(patch.getId(), "new-advisory");
    // App: policies
    Application policies = findApp("rhel", "policies");
    EventType policyTriggered = findEventType("rhel", "policies", "policy-triggered");
    // App: vulnerability
    Application vulnerability = resourceHelpers.createApp(rhel.getId(), "vulnerability");
    EventType newCveCvss = resourceHelpers.createEventType(vulnerability.getId(), "new-cve-cvss");
    EventType newCveSeverity = resourceHelpers.createEventType(vulnerability.getId(), "new-cve-severity");
    EventType newCveSecurityRule = resourceHelpers.createEventType(vulnerability.getId(), "new-cve-security-rule");
    EventType anyCveKnownExploit = resourceHelpers.createEventType(vulnerability.getId(), "any-cve-known-exploit");
    /*
         * Bundle: openshift
         */
    Bundle openshift = resourceHelpers.createBundle("openshift");
    // App: advisor
    Application advisorOpenshift = resourceHelpers.createApp(openshift.getId(), "advisor");
    EventType newRecommendationOpenshift = resourceHelpers.createEventType(advisorOpenshift.getId(), "new-recommendation");
    /*
         * Bundle: application-services
         */
    Bundle applicationServices = resourceHelpers.createBundle("application-services");
    // App: rhosak
    Application rhosak = resourceHelpers.createApp(applicationServices.getId(), "rhosak");
    EventType scheduledUpgrade = resourceHelpers.createEventType(rhosak.getId(), "scheduled-upgrade");
    EventType disruption = resourceHelpers.createEventType(rhosak.getId(), "disruption");
    EventType instanceCreated = resourceHelpers.createEventType(rhosak.getId(), "instance-created");
    EventType instanceDeleted = resourceHelpers.createEventType(rhosak.getId(), "instance-deleted");
    EventType actionRequired = resourceHelpers.createEventType(rhosak.getId(), "action-required");
    /*
         * Bundle: ansible
         */
    Bundle ansible = resourceHelpers.createBundle("ansible");
    // App: reports
    Application reports = resourceHelpers.createApp(ansible.getId(), "reports");
    EventType reportAvailable = resourceHelpers.createEventType(reports.getId(), "report-available");
    /*
         * Bundle: console
         */
    Bundle console = findBundle("console");
    // App: notifications
    Application notifications = findApp("console", "notifications");
    EventType failedIntegration = resourceHelpers.createEventType(notifications.getId(), "failed-integration");
    // App: sources
    Application sources = resourceHelpers.createApp(console.getId(), "sources");
    EventType availabilityStatus = resourceHelpers.createEventType(sources.getId(), "availability-status");
    // App: rbac
    Application rbac = resourceHelpers.createApp(console.getId(), "rbac");
    EventType rhNewRoleAvailable = resourceHelpers.createEventType(rbac.getId(), "rh-new-role-available");
    EventType rhPlatformDefaultRoleUpdated = resourceHelpers.createEventType(rbac.getId(), "rh-platform-default-role-updated");
    EventType rhNonPlatformDefaultRoleUpdated = resourceHelpers.createEventType(rbac.getId(), "rh-non-platform-default-role-updated");
    EventType customRoleCreated = resourceHelpers.createEventType(rbac.getId(), "custom-role-created");
    EventType customRoleUpdated = resourceHelpers.createEventType(rbac.getId(), "custom-role-updated");
    EventType customRoleDeleted = resourceHelpers.createEventType(rbac.getId(), "custom-role-deleted");
    EventType rhNewRoleAddedToDefaultAccess = resourceHelpers.createEventType(rbac.getId(), "rh-new-role-added-to-default-access");
    EventType rhRoleRemovedFromDefaultAccess = resourceHelpers.createEventType(rbac.getId(), "rh-role-removed-from-default-access");
    EventType customDefaultAccessUpdated = resourceHelpers.createEventType(rbac.getId(), "custom-default-access-updated");
    EventType groupCreated = resourceHelpers.createEventType(rbac.getId(), "group-created");
    EventType groupUpdated = resourceHelpers.createEventType(rbac.getId(), "group-updated");
    EventType groupDeleted = resourceHelpers.createEventType(rbac.getId(), "group-deleted");
    EventType platformDefaultGroupTurnedIntoCustom = resourceHelpers.createEventType(rbac.getId(), "platform-default-group-turned-into-custom");
    clearDbTemplates();
    given().basePath(API_INTERNAL).when().put("/template-engine/migrate").then().statusCode(200).contentType(JSON);
    statelessSessionFactory.withSession(statelessSession -> {
        /*
             * Bundle: rhel
             */
        // App: advisor
        findAndCompileInstantEmailTemplate(newRecommendation.getId());
        findAndCompileInstantEmailTemplate(resolvedRecommendation.getId());
        findAndCompileInstantEmailTemplate(deactivatedRecommendation.getId());
        assertTrue(templateRepository.findAggregationEmailTemplate(rhel.getName(), advisor.getName(), DAILY).isEmpty());
        // App: compliance
        findAndCompileInstantEmailTemplate(complianceBelowThreshold.getId());
        findAndCompileInstantEmailTemplate(reportUploadFailed.getId());
        findAndCompileAggregationEmailTemplate(rhel.getName(), compliance.getName(), DAILY);
        // App: drift
        findAndCompileInstantEmailTemplate(driftBaselineDetected.getId());
        findAndCompileAggregationEmailTemplate(rhel.getName(), drift.getName(), DAILY);
        // App: edge-management
        findAndCompileInstantEmailTemplate(imageCreation.getId());
        findAndCompileInstantEmailTemplate(updateDevices.getId());
        // App: patch
        findAndCompileInstantEmailTemplate(newAdvisories.getId());
        findAndCompileAggregationEmailTemplate(rhel.getName(), patch.getName(), DAILY);
        // App: policies
        findAndCompileInstantEmailTemplate(policyTriggered.getId());
        findAndCompileAggregationEmailTemplate(rhel.getName(), policies.getName(), DAILY);
        // App: vulnerability
        findAndCompileInstantEmailTemplate(newCveCvss.getId());
        findAndCompileInstantEmailTemplate(newCveSecurityRule.getId());
        findAndCompileInstantEmailTemplate(newCveSeverity.getId());
        findAndCompileInstantEmailTemplate(anyCveKnownExploit.getId());
        findAndCompileAggregationEmailTemplate(rhel.getName(), vulnerability.getName(), DAILY);
        /*
             * Bundle: openshift
             */
        // App: advisor
        findAndCompileInstantEmailTemplate(newRecommendationOpenshift.getId());
        assertTrue(templateRepository.findAggregationEmailTemplate(openshift.getName(), advisorOpenshift.getName(), DAILY).isEmpty());
        /*
             * Bundle: application-services
             */
        // App: rhosak
        findAndCompileInstantEmailTemplate(scheduledUpgrade.getId());
        findAndCompileInstantEmailTemplate(disruption.getId());
        findAndCompileInstantEmailTemplate(instanceCreated.getId());
        findAndCompileInstantEmailTemplate(instanceDeleted.getId());
        findAndCompileInstantEmailTemplate(actionRequired.getId());
        findAndCompileAggregationEmailTemplate(applicationServices.getName(), rhosak.getName(), DAILY);
        /*
             * Bundle: ansible
             */
        // App: reports
        findAndCompileInstantEmailTemplate(reportAvailable.getId());
        assertTrue(templateRepository.findAggregationEmailTemplate(ansible.getName(), reports.getName(), DAILY).isEmpty());
        /*
             * Bundle: console
             */
        // App: notifications
        findAndCompileInstantEmailTemplate(failedIntegration.getId());
        assertTrue(templateRepository.findAggregationEmailTemplate(console.getName(), notifications.getName(), DAILY).isEmpty());
        // App: sources
        findAndCompileInstantEmailTemplate(availabilityStatus.getId());
        assertTrue(templateRepository.findAggregationEmailTemplate(console.getName(), sources.getName(), DAILY).isEmpty());
        // App: rbac
        findAndCompileInstantEmailTemplate(rhNewRoleAvailable.getId());
        findAndCompileInstantEmailTemplate(rhPlatformDefaultRoleUpdated.getId());
        findAndCompileInstantEmailTemplate(rhNonPlatformDefaultRoleUpdated.getId());
        findAndCompileInstantEmailTemplate(customRoleCreated.getId());
        findAndCompileInstantEmailTemplate(customRoleUpdated.getId());
        findAndCompileInstantEmailTemplate(customRoleDeleted.getId());
        findAndCompileInstantEmailTemplate(rhNewRoleAddedToDefaultAccess.getId());
        findAndCompileInstantEmailTemplate(rhRoleRemovedFromDefaultAccess.getId());
        findAndCompileInstantEmailTemplate(customDefaultAccessUpdated.getId());
        findAndCompileInstantEmailTemplate(groupCreated.getId());
        findAndCompileInstantEmailTemplate(groupUpdated.getId());
        findAndCompileInstantEmailTemplate(groupDeleted.getId());
        findAndCompileInstantEmailTemplate(platformDefaultGroupTurnedIntoCustom.getId());
        assertTrue(templateRepository.findAggregationEmailTemplate(console.getName(), rbac.getName(), DAILY).isEmpty());
    });
    clearDbTemplates();
}
Also used : EventType(com.redhat.cloud.notifications.models.EventType) Bundle(com.redhat.cloud.notifications.models.Bundle) Application(com.redhat.cloud.notifications.models.Application) QuarkusTest(io.quarkus.test.junit.QuarkusTest) Test(org.junit.jupiter.api.Test)

Example 34 with EventType

use of com.redhat.cloud.notifications.models.EventType in project notifications-backend by RedHatInsights.

the class EventLogCleanerTest method createEventType.

private EventType createEventType() {
    Bundle bundle = new Bundle();
    bundle.setName("bundle");
    bundle.setDisplayName("Bundle");
    bundle.prePersist();
    entityManager.persist(bundle);
    Application app = new Application();
    app.setBundle(bundle);
    app.setBundleId(bundle.getId());
    app.setName("app");
    app.setDisplayName("Application");
    app.prePersist();
    entityManager.persist(app);
    EventType eventType = new EventType();
    eventType.setApplication(app);
    eventType.setApplicationId(app.getId());
    eventType.setName("event-type");
    eventType.setDisplayName("Event type");
    entityManager.persist(eventType);
    return eventType;
}
Also used : EventType(com.redhat.cloud.notifications.models.EventType) Bundle(com.redhat.cloud.notifications.models.Bundle) Application(com.redhat.cloud.notifications.models.Application)

Example 35 with EventType

use of com.redhat.cloud.notifications.models.EventType in project notifications-backend by RedHatInsights.

the class EventResourceTest method testAllQueryParams.

@Test
void testAllQueryParams() {
    /*
         * This method is very long, but splitting it into several smaller ones would mean we have to recreate lots of
         * database records for each test. To avoid doing that, the data is only persisted once and many tests are run
         * from the same data.
         */
    Header defaultIdentityHeader = mockRbac(DEFAULT_ACCOUNT_ID, DEFAULT_ORG_ID, "user", FULL_ACCESS);
    Header otherIdentityHeader = mockRbac(OTHER_ACCOUNT_ID, DEFAULT_ORG_ID, "other-username", FULL_ACCESS);
    Bundle bundle1 = resourceHelpers.createBundle("bundle-1", "Bundle 1");
    Bundle bundle2 = resourceHelpers.createBundle("bundle-2", "Bundle 2");
    Application app1 = resourceHelpers.createApplication(bundle1.getId(), "app-1", "Application 1");
    Application app2 = resourceHelpers.createApplication(bundle2.getId(), "app-2", "Application 2");
    EventType eventType1 = resourceHelpers.createEventType(app1.getId(), "event-type-1", "Event type 1", "Event type 1");
    EventType eventType2 = resourceHelpers.createEventType(app2.getId(), "event-type-2", "Event type 2", "Event type 2");
    Event event1 = createEvent(DEFAULT_ACCOUNT_ID, bundle1, app1, eventType1, NOW.minusDays(5L));
    Event event2 = createEvent(DEFAULT_ACCOUNT_ID, bundle2, app2, eventType2, NOW);
    Event event3 = createEvent(DEFAULT_ACCOUNT_ID, bundle2, app2, eventType2, NOW.minusDays(2L));
    Event event4 = createEvent(OTHER_ACCOUNT_ID, bundle2, app2, eventType2, NOW.minusDays(10L));
    Endpoint endpoint1 = resourceHelpers.createEndpoint(DEFAULT_ACCOUNT_ID, WEBHOOK);
    Endpoint endpoint2 = resourceHelpers.createEndpoint(DEFAULT_ACCOUNT_ID, EMAIL_SUBSCRIPTION);
    Endpoint endpoint3 = resourceHelpers.createEndpoint(DEFAULT_ACCOUNT_ID, CAMEL, "SlAcK");
    NotificationHistory history1 = resourceHelpers.createNotificationHistory(event1, endpoint1, TRUE);
    NotificationHistory history2 = resourceHelpers.createNotificationHistory(event1, endpoint2, FALSE);
    NotificationHistory history3 = resourceHelpers.createNotificationHistory(event2, endpoint1, TRUE);
    NotificationHistory history4 = resourceHelpers.createNotificationHistory(event3, endpoint2, TRUE);
    NotificationHistory history5 = resourceHelpers.createNotificationHistory(event3, endpoint3, TRUE);
    endpointRepository.deleteEndpoint(DEFAULT_ACCOUNT_ID, endpoint1.getId());
    endpointRepository.deleteEndpoint(DEFAULT_ACCOUNT_ID, endpoint2.getId());
    endpointRepository.deleteEndpoint(DEFAULT_ACCOUNT_ID, endpoint3.getId());
    /*
         * Test #1
         * Account: DEFAULT_ACCOUNT_ID
         * Request: No filter
         * Expected response: All event log entries from DEFAULT_ACCOUNT_ID should be returned
         */
    Page<EventLogEntry> page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, null, null, null, false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event3, history4, history5);
    assertSameEvent(page.getData().get(2), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #2
         * Account: OTHER_ACCOUNT_ID
         * Request: No filter
         * Expected response: All event log entries from OTHER_ACCOUNT_ID should be returned
         */
    page = getEventLogPage(otherIdentityHeader, null, null, null, null, null, null, null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event4);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #3
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Unknown bundle
         */
    page = getEventLogPage(defaultIdentityHeader, Set.of(randomUUID()), null, null, null, null, null, null, null, null, null, false, true);
    assertEquals(0, page.getMeta().getCount());
    assertTrue(page.getData().isEmpty());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #4
         * Account: DEFAULT_ACCOUNT_ID
         * Request: One existing bundle
         */
    page = getEventLogPage(defaultIdentityHeader, Set.of(bundle1.getId()), null, null, null, null, null, null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #5
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Multiple existing bundles, sort by ascending bundle names
         */
    page = getEventLogPage(defaultIdentityHeader, Set.of(bundle1.getId(), bundle2.getId()), null, null, null, null, null, null, null, null, "bundle:asc", false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertSameEvent(page.getData().get(1), event2, history3);
    assertSameEvent(page.getData().get(2), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #6
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Unknown application
         */
    page = getEventLogPage(defaultIdentityHeader, null, Set.of(randomUUID()), null, null, null, null, null, null, null, null, false, true);
    assertEquals(0, page.getMeta().getCount());
    assertTrue(page.getData().isEmpty());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #7
         * Account: DEFAULT_ACCOUNT_ID
         * Request: One existing application
         */
    page = getEventLogPage(defaultIdentityHeader, null, Set.of(app2.getId()), null, null, null, null, null, null, null, null, false, true);
    assertEquals(2, page.getMeta().getCount());
    assertEquals(2, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #8
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Multiple existing applications, sort by ascending application names
         */
    page = getEventLogPage(defaultIdentityHeader, null, Set.of(app1.getId(), app2.getId()), null, null, null, null, null, null, null, "application:asc", false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertSameEvent(page.getData().get(1), event2, history3);
    assertSameEvent(page.getData().get(2), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #9
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Unknown event type
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, "unknown", null, null, null, null, null, null, null, false, true);
    assertEquals(0, page.getMeta().getCount());
    assertTrue(page.getData().isEmpty());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #10
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Existing event type
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, eventType1.getDisplayName().substring(2).toUpperCase(), null, null, null, null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #11
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Start date three days in the past
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, NOW.minusDays(3L), null, null, null, null, null, null, false, true);
    assertEquals(2, page.getMeta().getCount());
    assertEquals(2, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #12
         * Account: DEFAULT_ACCOUNT_ID
         * Request: End date three days in the past
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, NOW.minusDays(3L), null, null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #13
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Both start and end date are set
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, NOW.minusDays(3L), NOW.minusDays(1L), null, null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #14
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Let's try all request params at once!
         */
    page = getEventLogPage(defaultIdentityHeader, Set.of(bundle2.getId()), Set.of(app2.getId()), eventType2.getDisplayName(), NOW.minusDays(3L), NOW.minusDays(1L), Set.of(EMAIL_SUBSCRIPTION.name()), Set.of(TRUE), 10, 0, "created:desc", true, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event3, history4, history5);
    assertEquals(PAYLOAD, page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #15
         * Account: DEFAULT_ACCOUNT_ID
         * Request: No filter, limit without offset
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, 2, null, null, false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(2, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last", "next");
    /*
         * Test #16
         * Account: DEFAULT_ACCOUNT_ID
         * Request: No filter, limit with offset
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, 1, 2, null, false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last", "prev");
    /*
         * Test #17
         * Account: DEFAULT_ACCOUNT_ID
         * Request: No filter, sort by ascending event names
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, null, null, "event:asc", false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertSameEvent(page.getData().get(1), event2, history3);
    assertSameEvent(page.getData().get(2), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #18
         * Account: DEFAULT_ACCOUNT_ID
         * Request: WEBHOOK endpoints
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of(WEBHOOK.name()), null, null, null, null, false, true);
    assertEquals(2, page.getMeta().getCount());
    assertEquals(2, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #19
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Invocation succeeded
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, Set.of(TRUE), null, null, null, false, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event3, history4, history5);
    assertSameEvent(page.getData().get(2), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #20
         * Account: DEFAULT_ACCOUNT_ID
         * Request: EMAIL_SUBSCRIPTION endpoints and invocation failed
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of(EMAIL_SUBSCRIPTION.name()), Set.of(FALSE), null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #21
         * Account: DEFAULT_ACCOUNT_ID
         * Request: No filter
         * Expected response: All event log entries from DEFAULT_ACCOUNT_ID should be returned without actions
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, null, null, null, false, false);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event2);
    assertSameEvent(page.getData().get(1), event3);
    assertSameEvent(page.getData().get(2), event1);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #22
         * Account: DEFAULT_ACCOUNT_ID
         * Request: CAMEL endpoints
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of(CAMEL.name()), null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #23
         * Account: DEFAULT_ACCOUNT_ID
         * Request: CAMEL:SPLUNK endpoints
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of("camel:splunk"), null, null, null, null, false, true);
    assertEquals(0, page.getMeta().getCount());
    assertEquals(0, page.getData().size());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #24
         * Account: DEFAULT_ACCOUNT_ID
         * Request: CAMEL:SLACK endpoints
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of("camel:slack"), null, null, null, null, false, true);
    assertEquals(1, page.getMeta().getCount());
    assertEquals(1, page.getData().size());
    assertSameEvent(page.getData().get(0), event3, history4, history5);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #25
         * Account: DEFAULT_ACCOUNT_ID
         * Request: CAMEL:SLACK and EMAIL endpoints
         */
    page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of("camel:SLACK", EMAIL_SUBSCRIPTION.name()), null, null, null, null, false, true);
    assertEquals(2, page.getMeta().getCount());
    assertEquals(2, page.getData().size());
    assertSameEvent(page.getData().get(0), event3, history4, history5);
    assertSameEvent(page.getData().get(1), event1, history1, history2);
    assertNull(page.getData().get(0).getPayload());
    assertLinks(page.getLinks(), "first", "last");
    /*
         * Test #26
         * Account: DEFAULT_ACCOUNT_ID
         * Request: Mixing bundle and an app from a different bundle
         */
    page = getEventLogPage(defaultIdentityHeader, Set.of(bundle1.getId()), Set.of(app2.getId()), null, null, null, null, null, 10, 0, null, true, true);
    assertEquals(3, page.getMeta().getCount());
    assertEquals(3, page.getData().size());
    assertSameEvent(page.getData().get(0), event2, history3);
    assertSameEvent(page.getData().get(1), event3, history4, history5);
    assertSameEvent(page.getData().get(2), event1, history1, history2);
    assertLinks(page.getLinks(), "first", "last");
}
Also used : Header(io.restassured.http.Header) Endpoint(com.redhat.cloud.notifications.models.Endpoint) EventType(com.redhat.cloud.notifications.models.EventType) NotificationHistory(com.redhat.cloud.notifications.models.NotificationHistory) Bundle(com.redhat.cloud.notifications.models.Bundle) EventLogEntry(com.redhat.cloud.notifications.routers.models.EventLogEntry) Event(com.redhat.cloud.notifications.models.Event) Application(com.redhat.cloud.notifications.models.Application) Test(org.junit.jupiter.api.Test) QuarkusTest(io.quarkus.test.junit.QuarkusTest) DbIsolatedTest(com.redhat.cloud.notifications.db.DbIsolatedTest)

Aggregations

EventType (com.redhat.cloud.notifications.models.EventType)36 QuarkusTest (io.quarkus.test.junit.QuarkusTest)16 Test (org.junit.jupiter.api.Test)16 Application (com.redhat.cloud.notifications.models.Application)14 Bundle (com.redhat.cloud.notifications.models.Bundle)11 Transactional (javax.transaction.Transactional)10 BehaviorGroup (com.redhat.cloud.notifications.models.BehaviorGroup)9 Action (com.redhat.cloud.notifications.ingress.Action)7 TestHelpers.serializeAction (com.redhat.cloud.notifications.TestHelpers.serializeAction)6 DbIsolatedTest (com.redhat.cloud.notifications.db.DbIsolatedTest)6 UUID (java.util.UUID)5 Event (com.redhat.cloud.notifications.models.Event)4 NotFoundException (javax.ws.rs.NotFoundException)4 AggregationEmailTemplate (com.redhat.cloud.notifications.models.AggregationEmailTemplate)3 InstantEmailTemplate (com.redhat.cloud.notifications.models.InstantEmailTemplate)3 Template (com.redhat.cloud.notifications.models.Template)3 Header (io.restassured.http.Header)3 Endpoint (com.redhat.cloud.notifications.models.Endpoint)2 JsonArray (io.vertx.core.json.JsonArray)2 JsonObject (io.vertx.core.json.JsonObject)2