Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
izeye authored Dec 4, 2024
1 parent 6b64447 commit 4606935
Showing 1 changed file with 10 additions and 23 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -127,8 +127,8 @@ else if (mbean.getName().contains("Cycles")) {
// cause GC to record new metrics
System.gc();

checkPhaseCount(initialPauseCount, initialConcurrentCount);
checkCollectionTime(initialPauseTimeMs, initialConcurrentTimeMs);
checkPhaseCountAndCollectionTime(initialPauseCount, initialConcurrentCount, initialPauseTimeMs,
initialConcurrentTimeMs);
}

static boolean isPauseCyclesGc() {
Expand Down Expand Up @@ -203,23 +203,30 @@ public void handleNotification(Notification notification, Object handback) {

}

private void checkPhaseCount(long initialPauseCount, long initialConcurrentCount) {
private void checkPhaseCountAndCollectionTime(long initialPauseCount, long initialConcurrentCount,
long initialPauseTimeMs, long initialConcurrentTimeMs) {
await().atMost(200, TimeUnit.MILLISECONDS).untilAsserted(() -> {
long pauseCount = 0;
long concurrentCount = 0;
long pauseTimeMs = 0;
long concurrentTimeMs = 0;

// get metrics from JMX again to obtain the difference
for (GarbageCollectorMXBean mbean : ManagementFactory.getGarbageCollectorMXBeans()) {
if (mbean.getName().contains("Pauses")) {
pauseCount += mbean.getCollectionCount();
pauseTimeMs += mbean.getCollectionTime();
}
else if (mbean.getName().contains("Cycles")) {
concurrentCount += mbean.getCollectionCount();
concurrentTimeMs += mbean.getCollectionTime();
}
}

long expectedPauseCount = pauseCount - initialPauseCount;
long expectedConcurrentCount = concurrentCount - initialConcurrentCount;
long expectedPauseTimeMs = pauseTimeMs - initialPauseTimeMs;
long expectedConcurrentTimeMs = concurrentTimeMs - initialConcurrentTimeMs;

long observedPauseCount = registry.find("jvm.gc.pause").timers().stream().mapToLong(Timer::count).sum();
long observedConcurrentCount = registry.find("jvm.gc.concurrent.phase.time")
Expand All @@ -229,26 +236,6 @@ else if (mbean.getName().contains("Cycles")) {
.sum();
assertThat(observedPauseCount).isEqualTo(expectedPauseCount);
assertThat(observedConcurrentCount).isEqualTo(expectedConcurrentCount);
});
}

private void checkCollectionTime(long initialPauseTimeMs, long initialConcurrentTimeMs) {
await().atMost(200, TimeUnit.MILLISECONDS).untilAsserted(() -> {
long pauseTimeMs = 0;
long concurrentTimeMs = 0;

// get metrics from JMX again to obtain the difference
for (GarbageCollectorMXBean mbean : ManagementFactory.getGarbageCollectorMXBeans()) {
if (mbean.getName().contains("Pauses")) {
pauseTimeMs += mbean.getCollectionTime();
}
else if (mbean.getName().contains("Cycles")) {
concurrentTimeMs += mbean.getCollectionTime();
}
}

long expectedPauseTimeMs = pauseTimeMs - initialPauseTimeMs;
long expectedConcurrentTimeMs = concurrentTimeMs - initialConcurrentTimeMs;

double observedPauseTimeMs = registry.find("jvm.gc.pause")
.timers()
Expand Down

0 comments on commit 4606935

Please sign in to comment.