From cc04c6ab95588165f493dd7c2f12ab6b232929e6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timoth=C3=A9e=20Bavelier?= Date: Fri, 23 Aug 2024 10:53:39 +0200 Subject: [PATCH 1/3] parseInt if string and fallback to default if unable to parse & tests --- .../java/org/datadog/jmxfetch/Instance.java | 7 ++++++ .../org/datadog/jmxfetch/TestInstance.java | 25 +++++++++++++++++++ ..._parsable_max_returned_metrics_string.yaml | 9 +++++++ ..._parsable_max_returned_metrics_string.yaml | 10 ++++++++ 4 files changed, 51 insertions(+) create mode 100644 src/test/resources/jmx_non_parsable_max_returned_metrics_string.yaml create mode 100644 src/test/resources/jmx_parsable_max_returned_metrics_string.yaml diff --git a/src/main/java/org/datadog/jmxfetch/Instance.java b/src/main/java/org/datadog/jmxfetch/Instance.java index 65867e201..c17bb67dc 100644 --- a/src/main/java/org/datadog/jmxfetch/Instance.java +++ b/src/main/java/org/datadog/jmxfetch/Instance.java @@ -160,6 +160,13 @@ public Instance( Object maxReturnedMetrics = this.instanceMap.get("max_returned_metrics"); if (maxReturnedMetrics == null) { this.maxReturnedMetrics = MAX_RETURNED_METRICS; + } else if (maxReturnedMetrics instanceof String) { + try { + this.maxReturnedMetrics = Integer.parseInt((String) maxReturnedMetrics); + } catch (NumberFormatException e) { + log.warn("Cannot convert max_returned_metrics to integer in your instance configuration. Defaulting to '{}'.", MAX_RETURNED_METRICS); + this.maxReturnedMetrics = MAX_RETURNED_METRICS; + } } else { this.maxReturnedMetrics = (Integer) maxReturnedMetrics; } diff --git a/src/test/java/org/datadog/jmxfetch/TestInstance.java b/src/test/java/org/datadog/jmxfetch/TestInstance.java index 4fa8adf55..3a1d4b1a3 100644 --- a/src/test/java/org/datadog/jmxfetch/TestInstance.java +++ b/src/test/java/org/datadog/jmxfetch/TestInstance.java @@ -97,6 +97,31 @@ public void testBaselineDefaultHostname() throws Exception { } } + @Test + public void testParsableMaxReturnedMetrics() throws Exception { + SimpleTestJavaApp testApp = new SimpleTestJavaApp(); + // Populate testApp with a lot of metrics (>350) ! + testApp.populateHashMap(400); + // Exposing a few metrics through JMX + registerMBean(testApp, "org.datadog.jmxfetch.test:type=ParsableMaxReturnedMetricsTest"); + initApplication("jmx_parsable_max_returned_metrics_string.yaml"); + run(); + + List> metrics = getMetrics(); + assertEquals(429, metrics.size()); + } + + @Test + public void testNonParsableMaxReturnedMetrics() throws Exception { + registerMBean(new SimpleTestJavaApp(), "org.datadog.jmxfetch.test:type=NonParsableMaxReturnedMetricsTest"); + initApplication("jmx_non_parsable_max_returned_metrics_string.yaml"); + run(); + + // Despite non parsable max_returned_metrics, metrics should still be collected. + List> metrics = getMetrics(); + assertEquals(29, metrics.size()); + } + // assertServiceTags is used by testServiceTagGlobal and testServiceTagInstanceOverride private void assertServiceTag(List tagList, List services) throws Exception { for (String service: services) { diff --git a/src/test/resources/jmx_non_parsable_max_returned_metrics_string.yaml b/src/test/resources/jmx_non_parsable_max_returned_metrics_string.yaml new file mode 100644 index 000000000..4daf69e8a --- /dev/null +++ b/src/test/resources/jmx_non_parsable_max_returned_metrics_string.yaml @@ -0,0 +1,9 @@ +init_config: + +instances: + - process_name_regex: .*surefire.* + name: jmx_test_instance + max_returned_metrics: "foo" + conf: + - include: + domain: org.datadog.jmxfetch.test diff --git a/src/test/resources/jmx_parsable_max_returned_metrics_string.yaml b/src/test/resources/jmx_parsable_max_returned_metrics_string.yaml new file mode 100644 index 000000000..0502e9984 --- /dev/null +++ b/src/test/resources/jmx_parsable_max_returned_metrics_string.yaml @@ -0,0 +1,10 @@ +init_config: + +instances: + - process_name_regex: .*surefire.* + name: jmx_test_instance + max_returned_metrics: "500" + conf: + - include: + domain: org.datadog.jmxfetch.test + From eac6991d8d4d32c1c12809668d66894558f0af25 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timoth=C3=A9e=20Bavelier?= Date: Fri, 23 Aug 2024 11:34:51 +0200 Subject: [PATCH 2/3] break warn log for lint --- src/main/java/org/datadog/jmxfetch/Instance.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/main/java/org/datadog/jmxfetch/Instance.java b/src/main/java/org/datadog/jmxfetch/Instance.java index c17bb67dc..2290e20ee 100644 --- a/src/main/java/org/datadog/jmxfetch/Instance.java +++ b/src/main/java/org/datadog/jmxfetch/Instance.java @@ -164,7 +164,9 @@ public Instance( try { this.maxReturnedMetrics = Integer.parseInt((String) maxReturnedMetrics); } catch (NumberFormatException e) { - log.warn("Cannot convert max_returned_metrics to integer in your instance configuration. Defaulting to '{}'.", MAX_RETURNED_METRICS); + log.warn( + "Cannot convert max_returned_metrics to integer in your instance configuration. Defaulting to '{}'.", + MAX_RETURNED_METRICS); this.maxReturnedMetrics = MAX_RETURNED_METRICS; } } else { From 4138725dc3c97e396f0e905b03167bbfcaf26107 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timoth=C3=A9e=20Bavelier?= Date: Fri, 23 Aug 2024 11:46:51 +0200 Subject: [PATCH 3/3] lint fix --- src/main/java/org/datadog/jmxfetch/Instance.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/java/org/datadog/jmxfetch/Instance.java b/src/main/java/org/datadog/jmxfetch/Instance.java index 2290e20ee..06d860062 100644 --- a/src/main/java/org/datadog/jmxfetch/Instance.java +++ b/src/main/java/org/datadog/jmxfetch/Instance.java @@ -165,8 +165,8 @@ public Instance( this.maxReturnedMetrics = Integer.parseInt((String) maxReturnedMetrics); } catch (NumberFormatException e) { log.warn( - "Cannot convert max_returned_metrics to integer in your instance configuration. Defaulting to '{}'.", - MAX_RETURNED_METRICS); + "Cannot convert max_returned_metrics to integer in your instance configuration." + + " Defaulting to {}.", MAX_RETURNED_METRICS); this.maxReturnedMetrics = MAX_RETURNED_METRICS; } } else {