Search in sources :

Example 46 with Event

use of org.ff4j.audit.Event in project ff4j by ff4j.

the class AbstractEventRepositoryTest method testPieChart.

@Test
public void testPieChart() throws InterruptedException {
    long start = System.currentTimeMillis();
    Event evt1 = new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", EventConstants.ACTION_CREATE);
    Assert.assertTrue(repo.saveEvent(evt1));
    Thread.sleep(200);
    EventQueryDefinition eqd = new EventQueryDefinition(start - 10, System.currentTimeMillis());
    Assert.assertNotNull(repo.getFeatureUsagePieChart(eqd));
    Assert.assertNotNull(repo.getHostPieChart(eqd));
    Assert.assertNotNull(repo.getSourcePieChart(eqd));
    Assert.assertNotNull(repo.getUserPieChart(eqd));
    Assert.assertNotNull(repo.getHostBarChart(eqd));
    Assert.assertNotNull(repo.getSourceBarChart(eqd));
    Assert.assertNotNull(repo.getUserBarChart(eqd));
}
Also used : EventQueryDefinition(org.ff4j.audit.EventQueryDefinition) Event(org.ff4j.audit.Event) Test(org.junit.Test)

Example 47 with Event

use of org.ff4j.audit.Event in project ff4j by ff4j.

the class AbstractEventRepositoryTest method testSourceHitCount.

/**
 * TDD.
 */
@Test
public void testSourceHitCount() throws InterruptedException {
    long start = System.currentTimeMillis();
    // When
    for (int i = 0; i < 8; i++) {
        Thread.sleep(100);
        repo.saveEvent(new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", ACTION_CHECK_OK));
        repo.saveEvent(new Event(SOURCE_WEB, TARGET_FEATURE, "f2", ACTION_CHECK_OK));
    }
    Thread.sleep(200);
    repo.saveEvent(new Event(SOURCE_WEBAPI, TARGET_FEATURE, "f1", ACTION_CHECK_OK));
    Thread.sleep(200);
    // Then
    EventQueryDefinition testQuery = new EventQueryDefinition(start - 20, System.currentTimeMillis());
    Map<String, MutableHitCount> mapOfHit = repo.getSourceHitCount(testQuery);
    Assert.assertEquals(3, mapOfHit.size());
    Assert.assertTrue(mapOfHit.containsKey(SOURCE_JAVA));
    Assert.assertTrue(mapOfHit.containsKey(SOURCE_WEB));
    Assert.assertEquals(1, mapOfHit.get(SOURCE_WEBAPI).get());
}
Also used : EventQueryDefinition(org.ff4j.audit.EventQueryDefinition) Event(org.ff4j.audit.Event) MutableHitCount(org.ff4j.audit.MutableHitCount) Test(org.junit.Test)

Example 48 with Event

use of org.ff4j.audit.Event in project ff4j by ff4j.

the class AbstractEventRepositoryTest method testUserHitCount.

/**
 * TDD.
 */
@Test
public void testUserHitCount() throws InterruptedException {
    long start = System.currentTimeMillis();
    // When
    for (int i = 0; i < 8; i++) {
        Event e1 = new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", ACTION_CHECK_OK);
        e1.setUser("JOHN");
        repo.saveEvent(e1);
        Thread.sleep(100);
        Event e2 = new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", ACTION_CHECK_OK);
        e2.setUser("BOB");
        repo.saveEvent(e2);
        Thread.sleep(100);
    }
    Thread.sleep(200);
    // Then
    EventQueryDefinition testQuery = new EventQueryDefinition(start - 20, System.currentTimeMillis());
    Map<String, MutableHitCount> mapOfHit = repo.getUserHitCount(testQuery);
    Assert.assertEquals(2, mapOfHit.size());
    Assert.assertTrue(mapOfHit.containsKey("JOHN"));
    Assert.assertTrue(mapOfHit.containsKey("BOB"));
    Assert.assertEquals(8, mapOfHit.get("BOB").get());
}
Also used : EventQueryDefinition(org.ff4j.audit.EventQueryDefinition) Event(org.ff4j.audit.Event) MutableHitCount(org.ff4j.audit.MutableHitCount) Test(org.junit.Test)

Example 49 with Event

use of org.ff4j.audit.Event in project ff4j by ff4j.

the class AbstractEventRepositoryTest method testFeatureUsageHitCount.

@Test
public void testFeatureUsageHitCount() throws InterruptedException {
    long start = System.currentTimeMillis();
    // Create Event
    repo.saveEvent(new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", EventConstants.ACTION_CREATE));
    for (int i = 0; i < 8; i++) {
        Thread.sleep(100);
        repo.saveEvent(new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", EventConstants.ACTION_CHECK_OK));
        repo.saveEvent(new Event(SOURCE_WEB, TARGET_FEATURE, "f2", EventConstants.ACTION_CHECK_OK));
    }
    Thread.sleep(100);
    // Assert bar chart (2 bars with 8 and 8)
    EventQueryDefinition testQuery = new EventQueryDefinition(start, System.currentTimeMillis());
    // Assert Pie Chart (2 sectors with 8 and 8)
    Map<String, MutableHitCount> mapOfHit = repo.getFeatureUsageHitCount(testQuery);
    Assert.assertEquals(2, mapOfHit.size());
    Assert.assertTrue(mapOfHit.containsKey("f1"));
    Assert.assertTrue(mapOfHit.containsKey("f2"));
    Assert.assertEquals(8, mapOfHit.get("f1").get());
}
Also used : EventQueryDefinition(org.ff4j.audit.EventQueryDefinition) Event(org.ff4j.audit.Event) MutableHitCount(org.ff4j.audit.MutableHitCount) Test(org.junit.Test)

Example 50 with Event

use of org.ff4j.audit.Event in project ff4j by ff4j.

the class AbstractEventRepositoryTest method testGetEventByUID2.

/**
 * TDD.
 */
@Test
public void testGetEventByUID2() throws InterruptedException {
    // Given
    String dummyId = "1234-5678-9012-3456";
    Event evt1 = new Event(SOURCE_JAVA, TARGET_FEATURE, "f1", ACTION_CREATE);
    evt1.setUuid(dummyId);
    // When
    repo.saveEvent(evt1);
    // Let the store to be updated
    Thread.sleep(100);
    // Then
    Event evt = repo.getEventByUUID(dummyId, null);
    Assert.assertNotNull(evt);
}
Also used : Event(org.ff4j.audit.Event) Test(org.junit.Test)

Aggregations

Event (org.ff4j.audit.Event)56 Test (org.junit.Test)32 EventQueryDefinition (org.ff4j.audit.EventQueryDefinition)22 MutableHitCount (org.ff4j.audit.MutableHitCount)15 EventSeries (org.ff4j.audit.EventSeries)8 TimeSeriesChart (org.ff4j.audit.chart.TimeSeriesChart)8 JestResult (io.searchbox.client.JestResult)6 HashMap (java.util.HashMap)5 EventRepository (org.ff4j.audit.repository.EventRepository)4 InMemoryEventRepository (org.ff4j.audit.repository.InMemoryEventRepository)4 Date (java.util.Date)2 TreeMap (java.util.TreeMap)2 EventPublisher (org.ff4j.audit.EventPublisher)2 EventWorker (org.ff4j.audit.EventWorker)2 BarChart (org.ff4j.audit.chart.BarChart)2 Map (java.util.Map)1 ConcurrentHashMap (java.util.concurrent.ConcurrentHashMap)1 FF4j (org.ff4j.FF4j)1 Serie (org.ff4j.audit.chart.Serie)1 MongoEventMapper (org.ff4j.mongo.mapper.MongoEventMapper)1