From d3e8c10315a94872b4fa36da0e91ec8fb48e4894 Mon Sep 17 00:00:00 2001 From: Chenyang Ji Date: Mon, 18 Dec 2023 14:20:09 -0800 Subject: [PATCH] make the logic to decide enabled self-contained in each listener Signed-off-by: Chenyang Ji --- .../search/SearchWeightedRoutingIT.java | 2 +- .../search/stats/SearchStatsIT.java | 2 +- .../search/SearchRequestListenerManager.java | 62 ++--------- .../SearchRequestOperationsListener.java | 7 +- .../action/search/SearchRequestSlowLog.java | 29 ++--- .../action/search/SearchRequestStats.java | 5 +- .../action/search/TransportSearchAction.java | 31 ++++-- .../common/settings/ClusterSettings.java | 3 +- .../main/java/org/opensearch/node/Node.java | 18 +-- .../cluster/node/stats/NodeStatsTests.java | 6 +- .../SearchRequestListenerManagerTests.java | 104 ++++-------------- .../search/SearchRequestSlowLogTests.java | 2 +- .../snapshots/SnapshotResiliencyTests.java | 2 +- 13 files changed, 94 insertions(+), 179 deletions(-) diff --git a/server/src/internalClusterTest/java/org/opensearch/search/SearchWeightedRoutingIT.java b/server/src/internalClusterTest/java/org/opensearch/search/SearchWeightedRoutingIT.java index aa1fe695ecc12..d1e66c19c28e2 100644 --- a/server/src/internalClusterTest/java/org/opensearch/search/SearchWeightedRoutingIT.java +++ b/server/src/internalClusterTest/java/org/opensearch/search/SearchWeightedRoutingIT.java @@ -57,7 +57,7 @@ import java.util.stream.Collectors; import java.util.stream.Stream; -import static org.opensearch.action.search.TransportSearchAction.SEARCH_REQUEST_STATS_ENABLED_KEY; +import static org.opensearch.action.search.SearchRequestStats.SEARCH_REQUEST_STATS_ENABLED_KEY; import static org.opensearch.search.aggregations.AggregationBuilders.terms; import static org.opensearch.test.hamcrest.OpenSearchAssertions.assertAcked; import static org.hamcrest.Matchers.equalTo; diff --git a/server/src/internalClusterTest/java/org/opensearch/search/stats/SearchStatsIT.java b/server/src/internalClusterTest/java/org/opensearch/search/stats/SearchStatsIT.java index 253a8b2b14824..8fb3c57dd7680 100644 --- a/server/src/internalClusterTest/java/org/opensearch/search/stats/SearchStatsIT.java +++ b/server/src/internalClusterTest/java/org/opensearch/search/stats/SearchStatsIT.java @@ -64,7 +64,7 @@ import java.util.Set; import java.util.function.Function; -import static org.opensearch.action.search.TransportSearchAction.SEARCH_REQUEST_STATS_ENABLED_KEY; +import static org.opensearch.action.search.SearchRequestStats.SEARCH_REQUEST_STATS_ENABLED_KEY; import static org.opensearch.cluster.metadata.IndexMetadata.SETTING_NUMBER_OF_REPLICAS; import static org.opensearch.cluster.metadata.IndexMetadata.SETTING_NUMBER_OF_SHARDS; import static org.opensearch.index.query.QueryBuilders.matchAllQuery; diff --git a/server/src/main/java/org/opensearch/action/search/SearchRequestListenerManager.java b/server/src/main/java/org/opensearch/action/search/SearchRequestListenerManager.java index 25e44a0a562e8..884a09a60ec49 100644 --- a/server/src/main/java/org/opensearch/action/search/SearchRequestListenerManager.java +++ b/server/src/main/java/org/opensearch/action/search/SearchRequestListenerManager.java @@ -9,14 +9,12 @@ package org.opensearch.action.search; import org.apache.logging.log4j.Logger; -import org.opensearch.cluster.service.ClusterService; -import org.opensearch.common.settings.Setting; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; - +import java.util.stream.Stream; /** * SearchRequestListenerManager manages listeners registered to search requests, @@ -27,32 +25,18 @@ * @opensearch.internal */ public class SearchRequestListenerManager { - - private final ClusterService clusterService; - public static final String SEARCH_PHASE_TOOK_ENABLED_KEY = "search.phase_took_enabled"; - public static final Setting SEARCH_PHASE_TOOK_ENABLED = Setting.boolSetting( - SEARCH_PHASE_TOOK_ENABLED_KEY, - false, - Setting.Property.Dynamic, - Setting.Property.NodeScope - ); private final List searchRequestListenersList; - public SearchRequestListenerManager( - ClusterService clusterService - ) { - this.clusterService = clusterService; - searchRequestListenersList = new ArrayList<>(); - } - /** - * Add multiple {@link SearchRequestOperationsListener} to the searchRequestListenersList. + * Create the SearchRequestListenerManager and add multiple {@link SearchRequestOperationsListener} + * to the searchRequestListenersList. * Those enabled listeners will be executed during each search request. * * @param listeners Multiple SearchRequestOperationsListener object to add. * @throws IllegalArgumentException if any input listener is null or already exists in the list. */ - public void addListeners(SearchRequestOperationsListener... listeners) { + public SearchRequestListenerManager(SearchRequestOperationsListener... listeners) { + searchRequestListenersList = new ArrayList<>(); for (SearchRequestOperationsListener listener : listeners) { if (listener == null) { throw new IllegalArgumentException("listener must not be null"); @@ -64,22 +48,6 @@ public void addListeners(SearchRequestOperationsListener... listeners) { } } - /** - * Remove a {@link SearchRequestOperationsListener} from the searchRequestListenersList, - * - * @param listener A SearchRequestOperationsListener object to remove. - * @throws IllegalArgumentException if the input listener is null or already exists in the list. - */ - public void removeListener(SearchRequestOperationsListener listener) { - if (listener == null) { - throw new IllegalArgumentException("listener must not be null"); - } - if (!searchRequestListenersList.contains(listener)) { - throw new IllegalArgumentException("listener does not exist in the listeners list"); - } - searchRequestListenersList.remove(listener); - } - /** * Get searchRequestListenersList, * @@ -90,35 +58,23 @@ public List getListeners() { return searchRequestListenersList; } - /** * Create the {@link SearchRequestOperationsListener.CompositeListener} * with the all listeners enabled at cluster-level and request-level. * - * @param searchRequest The SearchRequest object. SearchRequestListenerManager will decide which request-level listeners to add based on states/flags of the request * @param logger Logger to be attached to the {@link SearchRequestOperationsListener.CompositeListener} * @param perRequestListeners the per-request listeners that can be optionally added to the returned CompositeListener list. * @return SearchRequestOperationsListener.CompositeListener */ public SearchRequestOperationsListener.CompositeListener buildCompositeListener( - SearchRequest searchRequest, Logger logger, SearchRequestOperationsListener... perRequestListeners ) { - final List searchListenersList = searchRequestListenersList.stream().filter(SearchRequestOperationsListener::getEnabled).collect(Collectors.toList()); + final List searchListenersList = Stream.concat( + searchRequestListenersList.stream(), + Arrays.stream(perRequestListeners) + ).filter(SearchRequestOperationsListener::getEnabled).collect(Collectors.toList()); - Arrays.stream(perRequestListeners).forEach((listener) -> { - if (listener != null && listener.getClass() == TransportSearchAction.SearchTimeProvider.class) { - TransportSearchAction.SearchTimeProvider timeProvider = (TransportSearchAction.SearchTimeProvider) listener; - // phase_took is enabled with request param and/or cluster setting - boolean phaseTookEnabled = (searchRequest.isPhaseTook() != null && searchRequest.isPhaseTook()) || - clusterService.getClusterSettings().get(SEARCH_PHASE_TOOK_ENABLED); - if (phaseTookEnabled) { - timeProvider.setPhaseTook(true); - searchListenersList.add(timeProvider); - } - } - }); return new SearchRequestOperationsListener.CompositeListener(searchListenersList, logger); } diff --git a/server/src/main/java/org/opensearch/action/search/SearchRequestOperationsListener.java b/server/src/main/java/org/opensearch/action/search/SearchRequestOperationsListener.java index 7e318a542c812..ecebabcf2b8ae 100644 --- a/server/src/main/java/org/opensearch/action/search/SearchRequestOperationsListener.java +++ b/server/src/main/java/org/opensearch/action/search/SearchRequestOperationsListener.java @@ -26,6 +26,7 @@ public abstract class SearchRequestOperationsListener { protected SearchRequestOperationsListener() { this.enabled = false; } + protected SearchRequestOperationsListener(boolean enabled) { this.enabled = enabled; } @@ -40,7 +41,6 @@ void onRequestStart(SearchRequestContext searchRequestContext) {} void onRequestEnd(SearchPhaseContext context, SearchRequestContext searchRequestContext) {} - boolean getEnabled() { return enabled; } @@ -62,6 +62,7 @@ static final class CompositeListener extends SearchRequestOperationsListener { CompositeListener(List listeners, Logger logger) { this.listeners = listeners; this.logger = logger; + this.setEnabled(true); } @Override @@ -118,5 +119,9 @@ public void onRequestEnd(SearchPhaseContext context, SearchRequestContext search } } } + + public List getListeners() { + return listeners; + } } } diff --git a/server/src/main/java/org/opensearch/action/search/SearchRequestSlowLog.java b/server/src/main/java/org/opensearch/action/search/SearchRequestSlowLog.java index 0fadbda6b62a9..7f25f9026f215 100644 --- a/server/src/main/java/org/opensearch/action/search/SearchRequestSlowLog.java +++ b/server/src/main/java/org/opensearch/action/search/SearchRequestSlowLog.java @@ -108,9 +108,7 @@ public final class SearchRequestSlowLog extends SearchRequestOperationsListener private static final ToXContent.Params FORMAT_PARAMS = new ToXContent.MapParams(Collections.singletonMap("pretty", "false")); - public SearchRequestSlowLog( - ClusterService clusterService - ) { + public SearchRequestSlowLog(ClusterService clusterService) { this(clusterService, LogManager.getLogger(CLUSTER_SEARCH_REQUEST_SLOWLOG_PREFIX)); // logger configured in log4j2.properties } @@ -118,11 +116,11 @@ public SearchRequestSlowLog( this.logger = logger; Loggers.setLevel(this.logger, SlowLogLevel.TRACE.name()); - this.warnThreshold = clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_WARN_SETTING).nanos(); - this.infoThreshold = clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_INFO_SETTING).nanos(); - this.debugThreshold = clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_DEBUG_SETTING).nanos(); - this.traceThreshold = clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_TRACE_SETTING).nanos(); - this.level = clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_LEVEL); + this.setWarnThreshold(clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_WARN_SETTING)); + this.setInfoThreshold(clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_INFO_SETTING)); + this.setDebugThreshold(clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_DEBUG_SETTING)); + this.setTraceThreshold(clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_TRACE_SETTING)); + this.setLevel(clusterService.getClusterSettings().get(CLUSTER_SEARCH_REQUEST_SLOWLOG_LEVEL)); clusterService.getClusterSettings() .addSettingsUpdateConsumer(CLUSTER_SEARCH_REQUEST_SLOWLOG_THRESHOLD_WARN_SETTING, this::setWarnThreshold); @@ -235,22 +233,22 @@ private static String escapeJson(String text) { void setWarnThreshold(TimeValue warnThreshold) { this.warnThreshold = warnThreshold.nanos(); - setEnabled(); + setEnabledIfThresholdExceed(); } void setInfoThreshold(TimeValue infoThreshold) { this.infoThreshold = infoThreshold.nanos(); - setEnabled(); + setEnabledIfThresholdExceed(); } void setDebugThreshold(TimeValue debugThreshold) { this.debugThreshold = debugThreshold.nanos(); - setEnabled(); + setEnabledIfThresholdExceed(); } void setTraceThreshold(TimeValue traceThreshold) { this.traceThreshold = traceThreshold.nanos(); - setEnabled(); + setEnabledIfThresholdExceed(); } void setLevel(SlowLogLevel level) { @@ -277,10 +275,7 @@ SlowLogLevel getLevel() { return level; } - private void setEnabled() { - super.setEnabled(this.warnThreshold >= 0 - || this.debugThreshold >= 0 - || this.infoThreshold >= 0 - || this.traceThreshold >= 0); + private void setEnabledIfThresholdExceed() { + super.setEnabled(this.warnThreshold >= 0 || this.debugThreshold >= 0 || this.infoThreshold >= 0 || this.traceThreshold >= 0); } } diff --git a/server/src/main/java/org/opensearch/action/search/SearchRequestStats.java b/server/src/main/java/org/opensearch/action/search/SearchRequestStats.java index 19cb9dc4b73d5..2b01be8149331 100644 --- a/server/src/main/java/org/opensearch/action/search/SearchRequestStats.java +++ b/server/src/main/java/org/opensearch/action/search/SearchRequestStats.java @@ -37,9 +37,8 @@ public final class SearchRequestStats extends SearchRequestOperationsListener { ); @Inject - public SearchRequestStats( - ClusterService clusterService - ) { + public SearchRequestStats(ClusterService clusterService) { + this.setEnabled(clusterService.getClusterSettings().get(SEARCH_REQUEST_STATS_ENABLED)); clusterService.getClusterSettings().addSettingsUpdateConsumer(SEARCH_REQUEST_STATS_ENABLED, this::setEnabled); for (SearchPhaseName searchPhaseName : SearchPhaseName.values()) { phaseStatsMap.put(searchPhaseName, new StatsHolder()); diff --git a/server/src/main/java/org/opensearch/action/search/TransportSearchAction.java b/server/src/main/java/org/opensearch/action/search/TransportSearchAction.java index 17b220ae324a4..2f03d21723b27 100644 --- a/server/src/main/java/org/opensearch/action/search/TransportSearchAction.java +++ b/server/src/main/java/org/opensearch/action/search/TransportSearchAction.java @@ -154,6 +154,14 @@ public class TransportSearchAction extends HandledTransportAction SEARCH_PHASE_TOOK_ENABLED = Setting.boolSetting( + SEARCH_PHASE_TOOK_ENABLED_KEY, + false, + Setting.Property.Dynamic, + Setting.Property.NodeScope + ); + private final NodeClient client; private final ThreadPool threadPool; private final ClusterService clusterService; @@ -277,7 +285,6 @@ static final class SearchTimeProvider extends SearchRequestOperationsListener { private final long absoluteStartMillis; private final long relativeStartNanos; private final LongSupplier relativeCurrentNanosProvider; - private boolean phaseTook = false; /** * Instantiates a new search time provider. The absolute start time is the real clock time @@ -304,12 +311,8 @@ long buildTookInMillis() { return TimeUnit.NANOSECONDS.toMillis(relativeCurrentNanosProvider.getAsLong() - relativeStartNanos); } - public void setPhaseTook(boolean phaseTook) { - this.phaseTook = phaseTook; - } - SearchResponse.PhaseTook getPhaseTook() { - if (phaseTook) { + if (getEnabled()) { Map phaseTookMap = new HashMap<>(); // Convert Map to Map for SearchResponse() for (SearchPhaseName searchPhaseName : phaseStatsMap.keySet()) { @@ -323,6 +326,20 @@ SearchResponse.PhaseTook getPhaseTook() { Map phaseStatsMap = new EnumMap<>(SearchPhaseName.class); + /** + * Set if this listener is enabled based on the cluster level setting + * and per request enable flags. + * + * @param enabledAtClusterLevel if the SearchTimeProvider listener is enabled at cluster level + * @param searchRequest the original Search Request + * @opensearch.internal + */ + + void setEnabled(boolean enabledAtClusterLevel, SearchRequest searchRequest) { + // phase_took is enabled wi th request param and/or cluster setting + super.setEnabled(enabledAtClusterLevel || (searchRequest.isPhaseTook() != null && searchRequest.isPhaseTook())); + } + @Override void onPhaseStart(SearchPhaseContext context) {} @@ -462,8 +479,8 @@ private void executeRequest( relativeStartNanos, System::nanoTime ); + timeProvider.setEnabled(clusterService.getClusterSettings().get(SEARCH_PHASE_TOOK_ENABLED), originalSearchRequest); SearchRequestOperationsListener.CompositeListener requestOperationsListeners = searchRequestListenerManager.buildCompositeListener( - originalSearchRequest, logger, timeProvider ); diff --git a/server/src/main/java/org/opensearch/common/settings/ClusterSettings.java b/server/src/main/java/org/opensearch/common/settings/ClusterSettings.java index af211661d42a4..386af977f2224 100644 --- a/server/src/main/java/org/opensearch/common/settings/ClusterSettings.java +++ b/server/src/main/java/org/opensearch/common/settings/ClusterSettings.java @@ -35,7 +35,6 @@ import org.opensearch.action.admin.cluster.configuration.TransportAddVotingConfigExclusionsAction; import org.opensearch.action.admin.indices.close.TransportCloseIndexAction; import org.opensearch.action.search.CreatePitController; -import org.opensearch.action.search.SearchRequestListenerManager; import org.opensearch.action.search.SearchRequestSlowLog; import org.opensearch.action.search.SearchRequestStats; import org.opensearch.action.search.TransportSearchAction; @@ -383,7 +382,7 @@ public void apply(Settings value, Settings current, Settings previous) { TransportSearchAction.SHARD_COUNT_LIMIT_SETTING, TransportSearchAction.SEARCH_CANCEL_AFTER_TIME_INTERVAL_SETTING, TransportSearchAction.SEARCH_QUERY_METRICS_ENABLED_SETTING, - SearchRequestListenerManager.SEARCH_PHASE_TOOK_ENABLED, + TransportSearchAction.SEARCH_PHASE_TOOK_ENABLED, SearchRequestStats.SEARCH_REQUEST_STATS_ENABLED, RemoteClusterService.REMOTE_CLUSTER_SKIP_UNAVAILABLE, SniffConnectionStrategy.REMOTE_CONNECTIONS_PER_CLUSTER, diff --git a/server/src/main/java/org/opensearch/node/Node.java b/server/src/main/java/org/opensearch/node/Node.java index 6acc5105b7b29..aadac4324211d 100644 --- a/server/src/main/java/org/opensearch/node/Node.java +++ b/server/src/main/java/org/opensearch/node/Node.java @@ -47,6 +47,7 @@ import org.opensearch.action.search.SearchExecutionStatsCollector; import org.opensearch.action.search.SearchPhaseController; import org.opensearch.action.search.SearchRequestListenerManager; +import org.opensearch.action.search.SearchRequestOperationsListener; import org.opensearch.action.search.SearchRequestSlowLog; import org.opensearch.action.search.SearchRequestStats; import org.opensearch.action.search.SearchTransportService; @@ -787,13 +788,6 @@ protected Node( final SearchRequestStats searchRequestStats = new SearchRequestStats(clusterService); final SearchRequestSlowLog searchRequestSlowLog = new SearchRequestSlowLog(clusterService); - // register all standard SearchRequestOperationsListeners to the SearchRequestListenerManager - final SearchRequestListenerManager searchRequestListenerManager = new SearchRequestListenerManager(clusterService); - searchRequestListenerManager.addListeners( - searchRequestStats, - searchRequestSlowLog - ); - remoteStoreStatsTrackerFactory = new RemoteStoreStatsTrackerFactory(clusterService, settings); final IndicesService indicesService = new IndicesService( settings, @@ -887,6 +881,16 @@ protected Node( ) .collect(Collectors.toList()); + // register all standard SearchRequestOperationsListeners to the SearchRequestListenerManager + final SearchRequestListenerManager searchRequestListenerManager = new SearchRequestListenerManager( + Stream.concat( + Stream.of(searchRequestStats, searchRequestSlowLog), + pluginComponents.stream() + .filter(p -> p instanceof SearchRequestOperationsListener) + .map(p -> (SearchRequestOperationsListener) p) + ).toArray(SearchRequestOperationsListener[]::new) + ); + ActionModule actionModule = new ActionModule( settings, clusterModule.getIndexNameExpressionResolver(), diff --git a/server/src/test/java/org/opensearch/action/admin/cluster/node/stats/NodeStatsTests.java b/server/src/test/java/org/opensearch/action/admin/cluster/node/stats/NodeStatsTests.java index 04593fc0b66be..c59342d0f4292 100644 --- a/server/src/test/java/org/opensearch/action/admin/cluster/node/stats/NodeStatsTests.java +++ b/server/src/test/java/org/opensearch/action/admin/cluster/node/stats/NodeStatsTests.java @@ -969,7 +969,11 @@ private static NodeIndicesStats getNodeIndicesStats(boolean remoteStoreStats) { new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), null ); - indicesStats = new NodeIndicesStats(new CommonStats(CommonStatsFlags.ALL), new HashMap<>(), new SearchRequestStats(clusterService)); + indicesStats = new NodeIndicesStats( + new CommonStats(CommonStatsFlags.ALL), + new HashMap<>(), + new SearchRequestStats(clusterService) + ); RemoteSegmentStats remoteSegmentStats = indicesStats.getSegments().getRemoteSegmentStats(); remoteSegmentStats.addUploadBytesStarted(10L); remoteSegmentStats.addUploadBytesSucceeded(10L); diff --git a/server/src/test/java/org/opensearch/action/search/SearchRequestListenerManagerTests.java b/server/src/test/java/org/opensearch/action/search/SearchRequestListenerManagerTests.java index 348049dacf667..c16841ae1ee17 100644 --- a/server/src/test/java/org/opensearch/action/search/SearchRequestListenerManagerTests.java +++ b/server/src/test/java/org/opensearch/action/search/SearchRequestListenerManagerTests.java @@ -8,67 +8,27 @@ package org.opensearch.action.search; -import org.opensearch.cluster.service.ClusterService; -import org.opensearch.common.settings.ClusterSettings; -import org.opensearch.common.settings.Settings; import org.opensearch.index.query.QueryBuilders; import org.opensearch.search.builder.SearchSourceBuilder; import org.opensearch.test.OpenSearchTestCase; -import java.lang.reflect.Field; import java.util.List; - public class SearchRequestListenerManagerTests extends OpenSearchTestCase { public void testAddAndGetListeners() { - ClusterService clusterService = new ClusterService( - Settings.EMPTY, - new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), - null - ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); SearchRequestOperationsListener testListener = createTestSearchRequestOperationsListener(); - listenerManager.addListeners(testListener); + SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(testListener); assertEquals(1, listenerManager.getListeners().size()); assertEquals(testListener, listenerManager.getListeners().get(0)); } - public void testRemoveListeners() { - ClusterService clusterService = new ClusterService( - Settings.EMPTY, - new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), - null - ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); - SearchRequestOperationsListener testListener1 = createTestSearchRequestOperationsListener(); - SearchRequestOperationsListener testListener2 = createTestSearchRequestOperationsListener(); - listenerManager.addListeners(testListener1, testListener2); - assertEquals(2, listenerManager.getListeners().size()); - listenerManager.removeListener(testListener2); - assertEquals(1, listenerManager.getListeners().size()); - assertEquals(testListener1, listenerManager.getListeners().get(0)); - } - - public void testStandardListenersEnabled() throws NoSuchFieldException, IllegalAccessException { - ClusterService clusterService = new ClusterService( - Settings.EMPTY, - new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), - null - ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); + public void testStandardListenersEnabled() { SearchRequestOperationsListener testListener1 = createTestSearchRequestOperationsListener(); SearchRequestOperationsListener testListener2 = createTestSearchRequestOperationsListener(); + SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(testListener1, testListener2); testListener2.setEnabled(true); - listenerManager.addListeners(testListener1, testListener2); - SearchSourceBuilder source = SearchSourceBuilder.searchSource().query(QueryBuilders.matchAllQuery()); - SearchRequest searchRequest = new SearchRequest().source(source); - SearchRequestOperationsListener.CompositeListener compositeListener = listenerManager.buildCompositeListener( - searchRequest, - logger - ); - Field listenersField = SearchRequestOperationsListener.CompositeListener.class.getDeclaredField("listeners"); - listenersField.setAccessible(true); - List listeners = (List) listenersField.get(compositeListener); + SearchRequestOperationsListener.CompositeListener compositeListener = listenerManager.buildCompositeListener(logger); + List listeners = compositeListener.getListeners(); assertEquals(1, listeners.size()); assertEquals(testListener2, listeners.get(0)); assertEquals(2, listenerManager.getListeners().size()); @@ -76,32 +36,25 @@ public void testStandardListenersEnabled() throws NoSuchFieldException, IllegalA assertEquals(testListener2, listenerManager.getListeners().get(1)); } - public void testStandardListenersAndTimeProvider() throws NoSuchFieldException, IllegalAccessException { - ClusterService clusterService = new ClusterService( - Settings.EMPTY, - new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), - null - ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); + public void testStandardListenersAndTimeProvider() { SearchRequestOperationsListener testListener1 = createTestSearchRequestOperationsListener(); + SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(testListener1); + testListener1.setEnabled(true); - SearchRequestOperationsListener timeProviderListener = new TransportSearchAction.SearchTimeProvider( + TransportSearchAction.SearchTimeProvider timeProviderListener = new TransportSearchAction.SearchTimeProvider( 0, System.nanoTime(), System::nanoTime ); - listenerManager.addListeners(testListener1); SearchSourceBuilder source = SearchSourceBuilder.searchSource().query(QueryBuilders.matchAllQuery()); SearchRequest searchRequest = new SearchRequest().source(source); searchRequest.setPhaseTook(true); + timeProviderListener.setEnabled(false, searchRequest); SearchRequestOperationsListener.CompositeListener compositeListener = listenerManager.buildCompositeListener( - searchRequest, logger, timeProviderListener ); - Field listenersField = SearchRequestOperationsListener.CompositeListener.class.getDeclaredField("listeners"); - listenersField.setAccessible(true); - List listeners = (List) listenersField.get(compositeListener); + List listeners = compositeListener.getListeners(); assertEquals(2, listeners.size()); assertEquals(testListener1, listeners.get(0)); assertEquals(timeProviderListener, listeners.get(1)); @@ -109,31 +62,23 @@ public void testStandardListenersAndTimeProvider() throws NoSuchFieldException, assertEquals(testListener1, listenerManager.getListeners().get(0)); } - public void testStandardListenersDisabledAndTimeProvider() throws NoSuchFieldException, IllegalAccessException { - ClusterService clusterService = new ClusterService( - Settings.EMPTY, - new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), - null - ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); + public void testStandardListenersDisabledAndTimeProvider() { SearchRequestOperationsListener testListener1 = createTestSearchRequestOperationsListener(); - SearchRequestOperationsListener timeProviderListener = new TransportSearchAction.SearchTimeProvider( + SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(testListener1); + TransportSearchAction.SearchTimeProvider timeProviderListener = new TransportSearchAction.SearchTimeProvider( 0, System.nanoTime(), System::nanoTime ); - listenerManager.addListeners(testListener1); SearchSourceBuilder source = SearchSourceBuilder.searchSource().query(QueryBuilders.matchAllQuery()); SearchRequest searchRequest = new SearchRequest().source(source); searchRequest.setPhaseTook(true); + timeProviderListener.setEnabled(false, searchRequest); SearchRequestOperationsListener.CompositeListener compositeListener = listenerManager.buildCompositeListener( - searchRequest, logger, timeProviderListener ); - Field listenersField = SearchRequestOperationsListener.CompositeListener.class.getDeclaredField("listeners"); - listenersField.setAccessible(true); - List listeners = (List) listenersField.get(compositeListener); + List listeners = compositeListener.getListeners(); assertEquals(1, listeners.size()); assertEquals(timeProviderListener, listeners.get(0)); assertEquals(1, listenerManager.getListeners().size()); @@ -141,39 +86,30 @@ public void testStandardListenersDisabledAndTimeProvider() throws NoSuchFieldExc assertFalse(listenerManager.getListeners().get(0).getEnabled()); } - public void testStandardListenerAndTimeProviderDisabled() throws NoSuchFieldException, IllegalAccessException { - ClusterService clusterService = new ClusterService( - Settings.EMPTY, - new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), - null - ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); + public void testStandardListenerAndTimeProviderDisabled() { SearchRequestOperationsListener testListener1 = createTestSearchRequestOperationsListener(); + SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(testListener1); + testListener1.setEnabled(true); SearchRequestOperationsListener timeProviderListener = new TransportSearchAction.SearchTimeProvider( 0, System.nanoTime(), System::nanoTime ); - listenerManager.addListeners(testListener1); SearchSourceBuilder source = SearchSourceBuilder.searchSource().query(QueryBuilders.matchAllQuery()); SearchRequest searchRequest = new SearchRequest().source(source); searchRequest.setPhaseTook(false); SearchRequestOperationsListener.CompositeListener compositeListener = listenerManager.buildCompositeListener( - searchRequest, logger, timeProviderListener ); - Field listenersField = SearchRequestOperationsListener.CompositeListener.class.getDeclaredField("listeners"); - listenersField.setAccessible(true); - List listeners = (List) listenersField.get(compositeListener); + List listeners = compositeListener.getListeners(); assertEquals(1, listeners.size()); assertEquals(testListener1, listeners.get(0)); assertEquals(1, listenerManager.getListeners().size()); assertEquals(testListener1, listenerManager.getListeners().get(0)); } - public SearchRequestOperationsListener createTestSearchRequestOperationsListener() { return new SearchRequestOperationsListener() { @Override diff --git a/server/src/test/java/org/opensearch/action/search/SearchRequestSlowLogTests.java b/server/src/test/java/org/opensearch/action/search/SearchRequestSlowLogTests.java index 5456ef02b9b8e..e70bba36445e0 100644 --- a/server/src/test/java/org/opensearch/action/search/SearchRequestSlowLogTests.java +++ b/server/src/test/java/org/opensearch/action/search/SearchRequestSlowLogTests.java @@ -104,7 +104,7 @@ public void testMultipleSlowLoggersUseSingleLog4jLogger() { new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), null ); - SearchRequestListenerManager listenerManager2 = new SearchRequestListenerManager(clusterService2); + SearchRequestListenerManager listenerManager2 = new SearchRequestListenerManager(); SearchRequestSlowLog searchRequestSlowLog2 = new SearchRequestSlowLog(clusterService2); int numberOfLoggersAfter = context.getLoggers().size(); diff --git a/server/src/test/java/org/opensearch/snapshots/SnapshotResiliencyTests.java b/server/src/test/java/org/opensearch/snapshots/SnapshotResiliencyTests.java index bf1a6e1593f4c..e631d3e67a484 100644 --- a/server/src/test/java/org/opensearch/snapshots/SnapshotResiliencyTests.java +++ b/server/src/test/java/org/opensearch/snapshots/SnapshotResiliencyTests.java @@ -2285,7 +2285,7 @@ public void onFailure(final Exception e) { writableRegistry(), searchService::aggReduceContextBuilder ); - SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(clusterService); + SearchRequestListenerManager listenerManager = new SearchRequestListenerManager(); actions.put( SearchAction.INSTANCE, new TransportSearchAction(