From 58fd752c876bdd665ee5490f9099927cd0352ffb Mon Sep 17 00:00:00 2001 From: arifBurakDemiray Date: Mon, 25 Sep 2023 11:20:34 +0300 Subject: [PATCH] refactor: recordEvent function --- .../sdk/java/internal/ModuleEventsTests.java | 21 ++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/sdk-java/src/test/java/ly/count/sdk/java/internal/ModuleEventsTests.java b/sdk-java/src/test/java/ly/count/sdk/java/internal/ModuleEventsTests.java index 924b6195d..2eac2cc7d 100644 --- a/sdk-java/src/test/java/ly/count/sdk/java/internal/ModuleEventsTests.java +++ b/sdk-java/src/test/java/ly/count/sdk/java/internal/ModuleEventsTests.java @@ -25,8 +25,9 @@ private void stop() { } /** - * Records an event and checks if it was recorded correctly - * by looking into event queue + * Recording an event with segmentation + * "recordEvent" function should create an event with given key and segmentation and add it to event queue + * recorded event should have correct key, segmentation, count, sum, duration, dow, hour and timestamp */ @Test public void recordEvent() { @@ -34,7 +35,8 @@ public void recordEvent() { config.enableFeatures(Config.Feature.Events).setEventQueueSizeToSend(4); init(config); - Assert.assertEquals(0, moduleEvents.eventQueue.eqSize()); + List events = TestUtils.getCurrentEventQueue(moduleEvents.ctx.getContext(), moduleEvents.L); + validateQueueSize(0, events); //create segmentation Map segmentation = new HashMap<>(); @@ -46,14 +48,14 @@ public void recordEvent() { Countly.instance().events().recordEvent("test-recordEvent", 1, 45.9, segmentation, 32.0); //check if event was recorded correctly and size of event queue is equal to size of events in queue - List events = TestUtils.getCurrentEventQueue(moduleEvents.ctx.getContext(), moduleEvents.L); - Assert.assertEquals(1, moduleEvents.eventQueue.eqSize()); - Assert.assertEquals(1, events.size()); + events = TestUtils.getCurrentEventQueue(moduleEvents.ctx.getContext(), moduleEvents.L); + validateQueueSize(1, events); //check if event was recorded correctly EventImpl event = events.get(0); + EventImpl eventInMemory = moduleEvents.eventQueue.eventQueueMemoryCache.get(0); validateEvent(event, "test-recordEvent", segmentation, 1, 45.9, 32.0, event.dow, event.hour, event.timestamp); - + validateEvent(eventInMemory, "test-recordEvent", segmentation, 1, 45.9, 32.0, event.dow, event.hour, event.timestamp); stop(); } @@ -281,6 +283,11 @@ public void endEvent_withSegmentation_negativeCount() { stop(); } + private void validateQueueSize(int expectedSize, List events) { + Assert.assertEquals(expectedSize, events.size()); + Assert.assertEquals(expectedSize, moduleEvents.eventQueue.eqSize()); + } + private void validateEvent(EventImpl gonnaValidate, String key, Map segmentation, int count, Double sum, Double duration, int dow, int hour, long timestamp) { Assert.assertEquals(key, gonnaValidate.key);