Skip to content

Commit

Permalink
8244291: Test: gc/z/TestGarbageCollectorMXBean.java failed: "unexpect…
Browse files Browse the repository at this point in the history
…ed cycles"

Reviewed-by: eosterlund, tschatzl
  • Loading branch information
pliden committed May 20, 2020
1 parent e9b8463 commit 58a34f7
Showing 1 changed file with 39 additions and 29 deletions.
68 changes: 39 additions & 29 deletions test/hotspot/jtreg/gc/z/TestGarbageCollectorMXBean.java
Expand Up @@ -34,13 +34,20 @@
import java.util.concurrent.atomic.AtomicInteger; import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicLong;
import javax.management.Notification; import javax.management.Notification;
import javax.management.NotificationBroadcaster; import javax.management.NotificationEmitter;
import javax.management.NotificationListener; import javax.management.NotificationListener;
import javax.management.openmbean.CompositeData; import javax.management.openmbean.CompositeData;


import com.sun.management.GarbageCollectionNotificationInfo; import com.sun.management.GarbageCollectionNotificationInfo;


public class TestGarbageCollectorMXBean { public class TestGarbageCollectorMXBean {
private static final long startTime = System.nanoTime();

private static void log(String msg) {
final String elapsedSeconds = String.format("%.3fs", (System.nanoTime() - startTime) / 1_000_000_000.0);
System.out.println("[" + elapsedSeconds + "] (" + Thread.currentThread().getName() + ") " + msg);
}

public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
final long M = 1024 * 1024; final long M = 1024 * 1024;
final long initialCapacity = Long.parseLong(args[0]) * M; final long initialCapacity = Long.parseLong(args[0]) * M;
Expand All @@ -67,61 +74,61 @@ public static void main(String[] args) throws Exception {
final var memoryUsageBeforeGC = info.getGcInfo().getMemoryUsageBeforeGc().get("ZHeap"); final var memoryUsageBeforeGC = info.getGcInfo().getMemoryUsageBeforeGc().get("ZHeap");
final var memoryUsageAfterGC = info.getGcInfo().getMemoryUsageAfterGc().get("ZHeap"); final var memoryUsageAfterGC = info.getGcInfo().getMemoryUsageAfterGc().get("ZHeap");


System.out.println(name + " (" + type + ")"); log(name + " (" + type + ")");
System.out.println(" Id: " + id); log(" Id: " + id);
System.out.println(" Action: " + action); log(" Action: " + action);
System.out.println(" Cause: " + cause); log(" Cause: " + cause);
System.out.println(" StartTime: " + startTime); log(" StartTime: " + startTime);
System.out.println(" EndTime: " + endTime); log(" EndTime: " + endTime);
System.out.println(" Duration: " + duration); log(" Duration: " + duration);
System.out.println(" MemoryUsageBeforeGC: " + memoryUsageBeforeGC); log(" MemoryUsageBeforeGC: " + memoryUsageBeforeGC);
System.out.println(" MemoryUsageAfterGC: " + memoryUsageAfterGC); log(" MemoryUsageAfterGC: " + memoryUsageAfterGC);
System.out.println(); log("");


if (name.equals("ZGC")) { if (name.equals("ZGC")) {
cycles.incrementAndGet(); cycles.incrementAndGet();
} else { } else {
System.out.println("ERROR: Name"); log("ERROR: Name");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (!action.equals("end of major GC")) { if (!action.equals("end of major GC")) {
System.out.println("ERROR: Action"); log("ERROR: Action");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (memoryUsageBeforeGC.getInit() != initialCapacity) { if (memoryUsageBeforeGC.getInit() != initialCapacity) {
System.out.println("ERROR: MemoryUsageBeforeGC.init"); log("ERROR: MemoryUsageBeforeGC.init");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (memoryUsageBeforeGC.getUsed() > initialCapacity) { if (memoryUsageBeforeGC.getUsed() > initialCapacity) {
System.out.println("ERROR: MemoryUsageBeforeGC.used"); log("ERROR: MemoryUsageBeforeGC.used");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (memoryUsageBeforeGC.getCommitted() != initialCapacity) { if (memoryUsageBeforeGC.getCommitted() != initialCapacity) {
System.out.println("ERROR: MemoryUsageBeforeGC.committed"); log("ERROR: MemoryUsageBeforeGC.committed");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (memoryUsageBeforeGC.getMax() != maxCapacity) { if (memoryUsageBeforeGC.getMax() != maxCapacity) {
System.out.println("ERROR: MemoryUsageBeforeGC.max"); log("ERROR: MemoryUsageBeforeGC.max");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (!cause.equals("System.gc()")) { if (!cause.equals("System.gc()")) {
System.out.println("ERROR: Cause"); log("ERROR: Cause");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (startTime > endTime) { if (startTime > endTime) {
System.out.println("ERROR: StartTime"); log("ERROR: StartTime");
errors.incrementAndGet(); errors.incrementAndGet();
} }


if (endTime - startTime != duration) { if (endTime - startTime != duration) {
System.out.println("ERROR: Duration"); log("ERROR: Duration");
errors.incrementAndGet(); errors.incrementAndGet();
} }
}; };
Expand All @@ -131,35 +138,38 @@ public static void main(String[] args) throws Exception {


// Register GC event listener // Register GC event listener
for (final var collector : ManagementFactory.getGarbageCollectorMXBeans()) { for (final var collector : ManagementFactory.getGarbageCollectorMXBeans()) {
final NotificationBroadcaster broadcaster = (NotificationBroadcaster)collector; final NotificationEmitter emitter = (NotificationEmitter)collector;
broadcaster.addNotificationListener(listener, null, null); emitter.addNotificationListener(listener, null, null);
} }


final int minCycles = 5; final int minCycles = 5;


// Run GCs // Run GCs
for (int i = 0; i < minCycles; i++) { for (int i = 0; i < minCycles; i++) {
log("Starting GC " + i);
System.gc(); System.gc();
} }


// Wait at most 60 seconds // Wait at most 90 seconds
for (int i = 0; i < 60; i++) { for (int i = 0; i < 90; i++) {
log("Waiting...");
Thread.sleep(1000); Thread.sleep(1000);

if (cycles.get() >= minCycles) { if (cycles.get() >= minCycles) {
// All events received log("All events received!");
break; break;
} }
} }


final int actualCycles = cycles.get(); final int actualCycles = cycles.get();
final int actualErrors = errors.get(); final int actualErrors = errors.get();


System.out.println(" minCycles: " + minCycles); log(" minCycles: " + minCycles);
System.out.println("actualCycles: " + actualCycles); log("actualCycles: " + actualCycles);
System.out.println("actualErrors: " + actualErrors); log("actualErrors: " + actualErrors);


// Verify number of cycle events // Verify number of cycle events
if (cycles.get() < minCycles) { if (actualCycles < minCycles) {
throw new Exception("Unexpected cycles"); throw new Exception("Unexpected cycles");
} }


Expand Down

0 comments on commit 58a34f7

Please sign in to comment.