From 4a478b8a98d00e1a5cda589e528a73135e783a5e Mon Sep 17 00:00:00 2001 From: Erik Gahlin Date: Thu, 7 Jan 2021 12:21:59 +0000 Subject: [PATCH] 8250903: jdk/jfr/javaagent/TestLoadedAgent.java fails with Mismatch in TestEvent count Reviewed-by: mgronlun --- .../jdk/jfr/javaagent/EventEmitterAgent.java | 21 ++++++------------- 1 file changed, 6 insertions(+), 15 deletions(-) diff --git a/test/jdk/jdk/jfr/javaagent/EventEmitterAgent.java b/test/jdk/jdk/jfr/javaagent/EventEmitterAgent.java index 0e19589d65d..5a4cd4f534f 100644 --- a/test/jdk/jdk/jfr/javaagent/EventEmitterAgent.java +++ b/test/jdk/jdk/jfr/javaagent/EventEmitterAgent.java @@ -35,12 +35,10 @@ import jdk.jfr.consumer.RecordingFile; import jdk.test.lib.Asserts; import jdk.test.lib.jfr.EventNames; -// Java agent that emits in multiple threads +// Java agent that emits events public class EventEmitterAgent { - private static final int THREADS = 5; - private static final int EVENTS_PER_THREAD = 150_000; - private static final int EXPECTED_COUNT = THREADS * EVENTS_PER_THREAD; + private static final long EVENTS = 150_000; private static final Path DUMP_PATH = Paths.get("dump.jfr").toAbsolutePath(); // Called when agent is loaded from command line @@ -58,20 +56,13 @@ public class EventEmitterAgent { r.enable(EventNames.JavaExceptionThrow); r.setDestination(DUMP_PATH); r.start(); - Thread[] threads = new Thread[THREADS]; - for (int i = 0; i < THREADS; i++) { - threads[i] = new Thread(EventEmitterAgent::emitEvents); - threads[i].start(); - } - for (int i = 0; i < THREADS; i++) { - threads[i].join(); - } + emitEvents(); r.stop(); } } public static void emitEvents() { - for (int i = 0; i < EVENTS_PER_THREAD; i++) { + for (int i = 0; i < EVENTS; i++) { TestEvent e = new TestEvent(); e.msg = "Long message that puts pressure on the string pool " + i % 100; e.count = i; @@ -80,7 +71,7 @@ public class EventEmitterAgent { e.commit(); if (i % 10000 == 0) { try { - Thread.sleep(1); + Thread.sleep(10); } catch (InterruptedException ie) { // ignore } @@ -101,6 +92,6 @@ public class EventEmitterAgent { .stream() .filter(e -> e.getEventType().getName().equals("Test")) .count(); - Asserts.assertTrue(testEventCount == EXPECTED_COUNT, "Mismatch in TestEvent count"); + Asserts.assertEquals(testEventCount, EVENTS, "Mismatch in TestEvent count"); } }