From e53a41f5de3cc62db53e020465399d78dca574b9 Mon Sep 17 00:00:00 2001 From: Bruno Baptista Date: Wed, 6 Nov 2024 09:42:10 +0000 Subject: [PATCH] Make jvm.thread.count assertion independent of the description (#246) --- .../metrics/tck/jvm/JvmThreadTest.java | 5 +- .../metrics/tck/jvm/MetricsReader.java | 63 +++++++++++++++++++ 2 files changed, 66 insertions(+), 2 deletions(-) diff --git a/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/JvmThreadTest.java b/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/JvmThreadTest.java index 997ba1e..1d26591 100644 --- a/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/JvmThreadTest.java +++ b/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/JvmThreadTest.java @@ -56,8 +56,9 @@ public static WebArchive createTestArchive() { @Test void testThreadCountMetric() throws IOException { - MetricsReader.assertLogMessage("jvm.thread.count", "Number of executing platform threads.", "{thread}", - MetricDataType.LONG_SUM.toString()); + MetricsReader.assertLogMessagePattern( + "name=jvm\\.thread\\.count, description=Number of executing(.*) threads(.*), unit=\\{thread\\}, type=" + + MetricDataType.LONG_SUM.toString()); } } diff --git a/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/MetricsReader.java b/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/MetricsReader.java index 968753a..5305c09 100644 --- a/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/MetricsReader.java +++ b/tck/metrics/src/main/java/org/eclipse/microprofile/telemetry/metrics/tck/jvm/MetricsReader.java @@ -25,6 +25,8 @@ import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; +import java.util.regex.Matcher; +import java.util.regex.Pattern; import org.apache.commons.io.input.Tailer; import org.apache.commons.io.input.TailerListenerAdapter; @@ -79,6 +81,40 @@ public static void assertLogMessage(String metricName, String metricDescription, } } + /** + * This method asserts that a log line matching the following format + * + * "searchPattern=" + * + * Can be found in the log file pointed to by the system property mptelemetry.tck.log.file.path. It will wait for up + * to fifteen seconds for the log to appear. + * + * @param searchPattern + * The pattern to search for in the log file + */ + public static void assertLogMessagePattern(String searchPattern) { + + ExecutorService es = Executors.newFixedThreadPool(1); + + LogFileTailerMatcherAdaptor logFileTailerAdaptor = + new LogFileTailerMatcherAdaptor(searchPattern); + + Tailer tailer = Tailer.builder() + .setStartThread(true) + .setPath(logFilePath) + .setExecutorService(es) + .setReOpen(false) + .setTailerListener(logFileTailerAdaptor) + .setTailFromEnd(false) + .get(); + + try (tailer) { + Awaitility.await().atMost(15, SECONDS) + .untilAsserted(() -> Assert.assertTrue(logFileTailerAdaptor.foundMetric(), + "Did not find " + searchPattern + " in logfile: " + logFilePath)); + } + } + private static class LogFileTailerAdaptor extends TailerListenerAdapter { private final String searchString; @@ -105,4 +141,31 @@ public boolean foundMetric() { } } + private static class LogFileTailerMatcherAdaptor extends TailerListenerAdapter { + + private final Pattern pattern; + private boolean foundMetric = false; + private Tailer tailer = null; + + public LogFileTailerMatcherAdaptor(String searchString) { + this.pattern = Pattern.compile(searchString); + } + + public void init(Tailer tailer) { + this.tailer = tailer; + } + + public void handle(String line) { + Matcher matcher = pattern.matcher(line); + if (matcher.find()) { + foundMetric = true; + tailer.close(); + } + } + + public boolean foundMetric() { + return foundMetric; + } + } + }