From 45dc4570689986c53f8c0dba8c6a70b2701f5f5e Mon Sep 17 00:00:00 2001 From: Chenyang Ji <cyji@amazon.com> Date: Wed, 18 Sep 2024 14:33:54 -0700 Subject: [PATCH] update PR based on comments Signed-off-by: Chenyang Ji <cyji@amazon.com> --- .../insights/core/service/QueryInsightsService.java | 8 ++++---- .../rules/model/healthStats/QueryGrouperHealthStats.java | 8 ++++---- .../insights/core/service/TopQueriesServiceTests.java | 6 +----- .../core/service/grouper/MinMaxHeapQueryGrouperTests.java | 1 - .../model/healthStats/QueryGrouperHealthStatsTests.java | 4 +--- .../model/healthStats/QueryInsightsHealthStatsTests.java | 6 ++---- .../model/healthStats/TopQueriesHealthStatsTests.java | 4 +--- 7 files changed, 13 insertions(+), 24 deletions(-) diff --git a/src/main/java/org/opensearch/plugin/insights/core/service/QueryInsightsService.java b/src/main/java/org/opensearch/plugin/insights/core/service/QueryInsightsService.java index 41cb8e62..bb215b8a 100644 --- a/src/main/java/org/opensearch/plugin/insights/core/service/QueryInsightsService.java +++ b/src/main/java/org/opensearch/plugin/insights/core/service/QueryInsightsService.java @@ -19,6 +19,7 @@ import java.util.List; import java.util.Map; import java.util.concurrent.LinkedBlockingQueue; +import java.util.stream.Collectors; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.opensearch.client.Client; @@ -449,10 +450,9 @@ protected void doClose() throws IOException { * @return QueryInsightsHealthStats */ public QueryInsightsHealthStats getHealthStats() { - Map<MetricType, TopQueriesHealthStats> topQueriesHealthStatsMap = new HashMap<>(); - for (Map.Entry<MetricType, TopQueriesService> entry : topQueriesServices.entrySet()) { - topQueriesHealthStatsMap.put(entry.getKey(), entry.getValue().getHealthStats()); - } + Map<MetricType, TopQueriesHealthStats> topQueriesHealthStatsMap = topQueriesServices.entrySet() + .stream() + .collect(Collectors.toMap(Map.Entry::getKey, entry -> entry.getValue().getHealthStats())); return new QueryInsightsHealthStats( threadPool.info(QUERY_INSIGHTS_EXECUTOR), this.queryRecordsQueue.size(), diff --git a/src/main/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStats.java b/src/main/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStats.java index 75d955d4..b908dd71 100644 --- a/src/main/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStats.java +++ b/src/main/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStats.java @@ -21,8 +21,8 @@ public class QueryGrouperHealthStats implements ToXContentFragment, Writeable { private final int queryGroupCount; private final int queryGroupHeapSize; - private static final String QUERY_GROUP_COUNT = "QueryGroupCount"; - private static final String QUERY_GROUP_HEAP_SIZE = "QueryGroupHeapSize"; + private static final String QUERY_GROUP_COUNT_TOTAL = "QueryGroupCount_Total"; + private static final String QUERY_GROUP_COUNT_MAX_HEAP = "QueryGroupCount_MaxHeap"; /** * Constructor to read QueryGrouperHealthStats from a StreamInput. @@ -67,8 +67,8 @@ public void writeTo(StreamOutput out) throws IOException { */ @Override public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException { - builder.field(QUERY_GROUP_COUNT, queryGroupCount); - builder.field(QUERY_GROUP_HEAP_SIZE, queryGroupHeapSize); + builder.field(QUERY_GROUP_COUNT_TOTAL, queryGroupCount); + builder.field(QUERY_GROUP_COUNT_MAX_HEAP, queryGroupHeapSize); return builder; } diff --git a/src/test/java/org/opensearch/plugin/insights/core/service/TopQueriesServiceTests.java b/src/test/java/org/opensearch/plugin/insights/core/service/TopQueriesServiceTests.java index 2846abcc..5ec6f643 100644 --- a/src/test/java/org/opensearch/plugin/insights/core/service/TopQueriesServiceTests.java +++ b/src/test/java/org/opensearch/plugin/insights/core/service/TopQueriesServiceTests.java @@ -149,7 +149,6 @@ public void testRollingWindowsWithDifferentGroup() { } public void testGetHealthStats_EmptyService() { - // Get the health stats from an empty TopQueriesService TopQueriesHealthStats healthStats = topQueriesService.getHealthStats(); // Validate the health stats assertNotNull(healthStats); @@ -160,16 +159,13 @@ public void testGetHealthStats_EmptyService() { } public void testGetHealthStats_WithData() { - // Add some mock records to the TopQueriesService List<SearchQueryRecord> records = QueryInsightsTestUtils.generateQueryInsightRecords(2); topQueriesService.consumeRecords(records); - // Get the health stats after adding data TopQueriesHealthStats healthStats = topQueriesService.getHealthStats(); - // Validate the health stats assertNotNull(healthStats); assertEquals(2, healthStats.getTopQueriesHeapSize()); // Since we added two records assertNotNull(healthStats.getQueryGrouperHealthStats()); - // Assuming no grouping by default, expect QueryGroupCount to be 2 + // Assuming no grouping by default, expect QueryGroupCount to be 0 assertEquals(0, healthStats.getQueryGrouperHealthStats().getQueryGroupCount()); } } diff --git a/src/test/java/org/opensearch/plugin/insights/core/service/grouper/MinMaxHeapQueryGrouperTests.java b/src/test/java/org/opensearch/plugin/insights/core/service/grouper/MinMaxHeapQueryGrouperTests.java index fb0b1a41..ec7ea309 100644 --- a/src/test/java/org/opensearch/plugin/insights/core/service/grouper/MinMaxHeapQueryGrouperTests.java +++ b/src/test/java/org/opensearch/plugin/insights/core/service/grouper/MinMaxHeapQueryGrouperTests.java @@ -694,7 +694,6 @@ public void testGetHealthStatsWithGroups() { QueryGrouperHealthStats healthStats = minMaxHeapQueryGrouper.getHealthStats(); // Verify that group count stats reflect the correct number of total groups assertEquals(2, healthStats.getQueryGroupCount()); - // Verify that heap size reflect the correct number of groups in max heap assertEquals(0, healthStats.getQueryGroupHeapSize()); } diff --git a/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStatsTests.java b/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStatsTests.java index a4a9cebc..cd03a710 100644 --- a/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStatsTests.java +++ b/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryGrouperHealthStatsTests.java @@ -38,21 +38,19 @@ public void testSerialization() throws IOException { // Read from StreamInput StreamInput in = StreamInput.wrap(out.bytes().toBytesRef().bytes); QueryGrouperHealthStats deserializedStats = new QueryGrouperHealthStats(in); - // Assert equality assertEquals(stats.getQueryGroupCount(), deserializedStats.getQueryGroupCount()); assertEquals(stats.getQueryGroupHeapSize(), deserializedStats.getQueryGroupHeapSize()); } public void testToXContent() throws IOException { QueryGrouperHealthStats stats = new QueryGrouperHealthStats(queryGroupCount, queryGroupHeapSize); - // Write to XContent XContentBuilder builder = XContentFactory.jsonBuilder(); builder.startObject(); stats.toXContent(builder, ToXContent.EMPTY_PARAMS); builder.endObject(); String expectedJson = String.format( Locale.ROOT, - "{\"QueryGroupCount\":%d,\"QueryGroupHeapSize\":%d}", + "{\"QueryGroupCount_Total\":%d,\"QueryGroupCount_MaxHeap\":%d}", queryGroupCount, queryGroupHeapSize ); diff --git a/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryInsightsHealthStatsTests.java b/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryInsightsHealthStatsTests.java index 1677ccae..ac4e8223 100644 --- a/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryInsightsHealthStatsTests.java +++ b/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/QueryInsightsHealthStatsTests.java @@ -69,7 +69,6 @@ public void testSerialization() throws IOException { // Read from StreamInput StreamInput in = StreamInput.wrap(out.bytes().toBytesRef().bytes); QueryInsightsHealthStats deserializedHealthStats = new QueryInsightsHealthStats(in); - // Assert equality assertEquals(healthStats.getQueryRecordsQueueSize(), deserializedHealthStats.getQueryRecordsQueueSize()); assertNotNull(deserializedHealthStats.getThreadPoolInfo()); assertNotNull(deserializedHealthStats.getTopQueriesHealthStats()); @@ -77,7 +76,6 @@ public void testSerialization() throws IOException { public void testToXContent() throws IOException { QueryInsightsHealthStats healthStats = new QueryInsightsHealthStats(threadPoolInfo, queryRecordsQueueSize, topQueriesHealthStats); - // Create XContentBuilder to build JSON XContentBuilder builder = XContentFactory.jsonBuilder(); builder.startObject(); @@ -99,8 +97,8 @@ public void testToXContent() throws IOException { + " \"TopQueriesHealthStats\": {\n" + " \"latency\": {\n" + " \"TopQueriesHeapSize\": 10,\n" - + " \"QueryGroupCount\": 20,\n" - + " \"QueryGroupHeapSize\": 15\n" + + " \"QueryGroupCount_Total\": 20,\n" + + " \"QueryGroupCount_MaxHeap\": 15\n" + " }\n" + " }\n" + "}"; diff --git a/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/TopQueriesHealthStatsTests.java b/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/TopQueriesHealthStatsTests.java index f84d7f0b..4a426e43 100644 --- a/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/TopQueriesHealthStatsTests.java +++ b/src/test/java/org/opensearch/plugin/insights/rules/model/healthStats/TopQueriesHealthStatsTests.java @@ -38,7 +38,6 @@ public void testSerialization() throws IOException { // Read from StreamInput StreamInput in = StreamInput.wrap(out.bytes().toBytesRef().bytes); TopQueriesHealthStats deserializedHealthStats = new TopQueriesHealthStats(in); - // Assert equality assertEquals(healthStats.getTopQueriesHeapSize(), deserializedHealthStats.getTopQueriesHeapSize()); assertNotNull(deserializedHealthStats.getQueryGrouperHealthStats()); assertEquals( @@ -53,14 +52,13 @@ public void testSerialization() throws IOException { public void testToXContent() throws IOException { TopQueriesHealthStats healthStats = new TopQueriesHealthStats(topQueriesHeapSize, queryGrouperHealthStats); - // Write to XContent XContentBuilder builder = XContentFactory.jsonBuilder(); builder.startObject(); healthStats.toXContent(builder, ToXContent.EMPTY_PARAMS); builder.endObject(); String expectedJson = String.format( Locale.ROOT, - "{\"TopQueriesHeapSize\":%d,\"QueryGroupCount\":%d,\"QueryGroupHeapSize\":%d}", + "{\"TopQueriesHeapSize\":%d,\"QueryGroupCount_Total\":%d,\"QueryGroupCount_MaxHeap\":%d}", topQueriesHeapSize, queryGrouperHealthStats.getQueryGroupCount(), queryGrouperHealthStats.getQueryGroupHeapSize()