8250903: jdk/jfr/javaagent/TestLoadedAgent.java fails with Mismatch in TestEvent count

Reviewed-by: mgronlun
This commit is contained in:
Erik Gahlin 2021-01-07 12:21:59 +00:00
parent 4f914e21c4
commit 4a478b8a98

View File

@ -35,12 +35,10 @@ import jdk.jfr.consumer.RecordingFile;
import jdk.test.lib.Asserts; import jdk.test.lib.Asserts;
import jdk.test.lib.jfr.EventNames; import jdk.test.lib.jfr.EventNames;
// Java agent that emits in multiple threads // Java agent that emits events
public class EventEmitterAgent { public class EventEmitterAgent {
private static final int THREADS = 5; private static final long EVENTS = 150_000;
private static final int EVENTS_PER_THREAD = 150_000;
private static final int EXPECTED_COUNT = THREADS * EVENTS_PER_THREAD;
private static final Path DUMP_PATH = Paths.get("dump.jfr").toAbsolutePath(); private static final Path DUMP_PATH = Paths.get("dump.jfr").toAbsolutePath();
// Called when agent is loaded from command line // Called when agent is loaded from command line
@ -58,20 +56,13 @@ public class EventEmitterAgent {
r.enable(EventNames.JavaExceptionThrow); r.enable(EventNames.JavaExceptionThrow);
r.setDestination(DUMP_PATH); r.setDestination(DUMP_PATH);
r.start(); r.start();
Thread[] threads = new Thread[THREADS]; emitEvents();
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();
}
r.stop(); r.stop();
} }
} }
public static void emitEvents() { public static void emitEvents() {
for (int i = 0; i < EVENTS_PER_THREAD; i++) { for (int i = 0; i < EVENTS; i++) {
TestEvent e = new TestEvent(); TestEvent e = new TestEvent();
e.msg = "Long message that puts pressure on the string pool " + i % 100; e.msg = "Long message that puts pressure on the string pool " + i % 100;
e.count = i; e.count = i;
@ -80,7 +71,7 @@ public class EventEmitterAgent {
e.commit(); e.commit();
if (i % 10000 == 0) { if (i % 10000 == 0) {
try { try {
Thread.sleep(1); Thread.sleep(10);
} catch (InterruptedException ie) { } catch (InterruptedException ie) {
// ignore // ignore
} }
@ -101,6 +92,6 @@ public class EventEmitterAgent {
.stream() .stream()
.filter(e -> e.getEventType().getName().equals("Test")) .filter(e -> e.getEventType().getName().equals("Test"))
.count(); .count();
Asserts.assertTrue(testEventCount == EXPECTED_COUNT, "Mismatch in TestEvent count"); Asserts.assertEquals(testEventCount, EVENTS, "Mismatch in TestEvent count");
} }
} }