From 100976e07289c00fbafb4d2aec5bd5a53fba858e Mon Sep 17 00:00:00 2001 From: Ajay Kumar Movva Date: Wed, 31 Jan 2024 23:26:05 +0530 Subject: [PATCH] Commented CPUBasedAdmissionControllerTests Tests Signed-off-by: Ajay Kumar Movva --- .../CPUBasedAdmissionControllerTests.java | 201 ++++++------ ...CPUBasedAdmissionControlSettingsTests.java | 290 +++++++++--------- 2 files changed, 245 insertions(+), 246 deletions(-) diff --git a/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/controllers/CPUBasedAdmissionControllerTests.java b/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/controllers/CPUBasedAdmissionControllerTests.java index 8e83cdfe6ff1f..b4b66ab56cb89 100644 --- a/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/controllers/CPUBasedAdmissionControllerTests.java +++ b/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/controllers/CPUBasedAdmissionControllerTests.java @@ -6,104 +6,103 @@ * compatible open source license. */ -// package org.opensearch.ratelimitting.admissioncontrol.controllers; -// -// import org.opensearch.cluster.service.ClusterService; -// import org.opensearch.common.settings.ClusterSettings; -// import org.opensearch.common.settings.Settings; -// import org.opensearch.ratelimitting.admissioncontrol.enums.AdmissionControlMode; -// import org.opensearch.ratelimitting.admissioncontrol.settings.CPUBasedAdmissionControllerSettings; -// import org.opensearch.test.OpenSearchTestCase; -// import org.opensearch.threadpool.TestThreadPool; -// import org.opensearch.threadpool.ThreadPool; -// -// public class CPUBasedAdmissionControllerTests extends OpenSearchTestCase { -// private ClusterService clusterService; -// private ThreadPool threadPool; -// CPUBasedAdmissionController admissionController = null; -// -// String action = "TEST_ACTION"; -// -// @Override -// public void setUp() throws Exception { -// super.setUp(); -// threadPool = new TestThreadPool("admission_controller_settings_test"); -// clusterService = new ClusterService( -// Settings.EMPTY, -// new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), -// threadPool -// ); -// } -// -// @Override -// public void tearDown() throws Exception { -// super.tearDown(); -// threadPool.shutdownNow(); -// } -// -// public void testCheckDefaultParameters() { -// admissionController = new CPUBasedAdmissionController( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, -// Settings.EMPTY, -// clusterService.getClusterSettings() -// ); -// assertEquals(admissionController.getName(), CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER); -// assertEquals(admissionController.getRejectionCount(), 0); -// assertEquals(admissionController.settings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.DISABLED); -// assertFalse( -// admissionController.isEnabledForTransportLayer(admissionController.settings.getTransportLayerAdmissionControllerMode()) -// ); -// } -// -// public void testCheckUpdateSettings() { -// admissionController = new CPUBasedAdmissionController( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, -// Settings.EMPTY, -// clusterService.getClusterSettings() -// ); -// Settings settings = Settings.builder() -// .put( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), -// AdmissionControlMode.ENFORCED.getMode() -// ) -// .build(); -// clusterService.getClusterSettings().applySettings(settings); -// -// assertEquals(admissionController.getName(), CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER); -// assertEquals(admissionController.getRejectionCount(), 0); -// assertEquals(admissionController.settings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); -// assertTrue(admissionController.isEnabledForTransportLayer(admissionController.settings.getTransportLayerAdmissionControllerMode())); -// } -// -// public void testApplyControllerWithDefaultSettings() { -// admissionController = new CPUBasedAdmissionController( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, -// Settings.EMPTY, -// clusterService.getClusterSettings() -// ); -// assertEquals(admissionController.getRejectionCount(), 0); -// assertEquals(admissionController.settings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.DISABLED); -// action = "indices:data/write/bulk[s][p]"; -// admissionController.apply(action); -// assertEquals(admissionController.getRejectionCount(), 0); -// } -// -// public void testApplyControllerWhenSettingsEnabled() { -// Settings settings = Settings.builder() -// .put( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), -// AdmissionControlMode.ENFORCED.getMode() -// ) -// .build(); -// admissionController = new CPUBasedAdmissionController( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, -// settings, -// clusterService.getClusterSettings() -// ); -// assertTrue(admissionController.isEnabledForTransportLayer(admissionController.settings.getTransportLayerAdmissionControllerMode())); -// assertEquals(admissionController.getRejectionCount(), 0); -// action = "indices:data/write/bulk[s][p]"; -// admissionController.apply(action); -// assertEquals(admissionController.getRejectionCount(), 1); -// } -// } +package org.opensearch.ratelimitting.admissioncontrol.controllers; + +import org.opensearch.cluster.service.ClusterService; +import org.opensearch.common.settings.ClusterSettings; +import org.opensearch.common.settings.Settings; +import org.opensearch.ratelimitting.admissioncontrol.enums.AdmissionControlMode; +import org.opensearch.ratelimitting.admissioncontrol.settings.CPUBasedAdmissionControllerSettings; +import org.opensearch.test.OpenSearchTestCase; +import org.opensearch.threadpool.TestThreadPool; +import org.opensearch.threadpool.ThreadPool; + +public class CPUBasedAdmissionControllerTests extends OpenSearchTestCase { + private ClusterService clusterService; + private ThreadPool threadPool; + + String action = "TEST_ACTION"; + + @Override + public void setUp() throws Exception { + super.setUp(); + threadPool = new TestThreadPool("admission_controller_settings_test"); + clusterService = new ClusterService( + Settings.EMPTY, + new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), + threadPool + ); + } + + @Override + public void tearDown() throws Exception { + super.tearDown(); + threadPool.shutdownNow(); + } + + public void testCheckDefaultParameters() { + CPUBasedAdmissionController admissionController = new CPUBasedAdmissionController( + CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, + Settings.EMPTY, + clusterService.getClusterSettings() + ); + assertEquals(admissionController.getName(), CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER); + assertEquals(admissionController.getRejectionCount(), 0); + assertEquals(admissionController.settings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.DISABLED); + assertFalse( + admissionController.isEnabledForTransportLayer(admissionController.settings.getTransportLayerAdmissionControllerMode()) + ); + } + + // public void testCheckUpdateSettings() { + // admissionController = new CPUBasedAdmissionController( + // CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, + // Settings.EMPTY, + // clusterService.getClusterSettings() + // ); + // Settings settings = Settings.builder() + // .put( + // CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), + // AdmissionControlMode.ENFORCED.getMode() + // ) + // .build(); + // clusterService.getClusterSettings().applySettings(settings); + // + // assertEquals(admissionController.getName(), CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER); + // assertEquals(admissionController.getRejectionCount(), 0); + // assertEquals(admissionController.settings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); + // assertTrue(admissionController.isEnabledForTransportLayer(admissionController.settings.getTransportLayerAdmissionControllerMode())); + // } + + // public void testApplyControllerWithDefaultSettings() { + // admissionController = new CPUBasedAdmissionController( + // CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, + // Settings.EMPTY, + // clusterService.getClusterSettings() + // ); + // assertEquals(admissionController.getRejectionCount(), 0); + // assertEquals(admissionController.settings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.DISABLED); + // action = "indices:data/write/bulk[s][p]"; + // admissionController.apply(action); + // assertEquals(admissionController.getRejectionCount(), 0); + // } + // + // public void testApplyControllerWhenSettingsEnabled() { + // Settings settings = Settings.builder() + // .put( + // CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), + // AdmissionControlMode.ENFORCED.getMode() + // ) + // .build(); + // admissionController = new CPUBasedAdmissionController( + // CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER, + // settings, + // clusterService.getClusterSettings() + // ); + // assertTrue(admissionController.isEnabledForTransportLayer(admissionController.settings.getTransportLayerAdmissionControllerMode())); + // assertEquals(admissionController.getRejectionCount(), 0); + // action = "indices:data/write/bulk[s][p]"; + // admissionController.apply(action); + // assertEquals(admissionController.getRejectionCount(), 1); + // } +} diff --git a/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/settings/CPUBasedAdmissionControlSettingsTests.java b/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/settings/CPUBasedAdmissionControlSettingsTests.java index fbb6094bb7a72..43103926a69a2 100644 --- a/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/settings/CPUBasedAdmissionControlSettingsTests.java +++ b/server/src/test/java/org/opensearch/ratelimitting/admissioncontrol/settings/CPUBasedAdmissionControlSettingsTests.java @@ -6,148 +6,148 @@ * compatible open source license. */ -// package org.opensearch.ratelimitting.admissioncontrol.settings; -// -// import org.opensearch.cluster.service.ClusterService; -// import org.opensearch.common.settings.ClusterSettings; -// import org.opensearch.common.settings.Setting; -// import org.opensearch.common.settings.Settings; -// import org.opensearch.ratelimitting.admissioncontrol.enums.AdmissionControlMode; -// import org.opensearch.test.OpenSearchTestCase; -// import org.opensearch.threadpool.TestThreadPool; -// import org.opensearch.threadpool.ThreadPool; -// -// import java.util.Arrays; -// import java.util.Set; -// -// public class CPUBasedAdmissionControlSettingsTests extends OpenSearchTestCase { -// private ClusterService clusterService; -// private ThreadPool threadPool; -// -// @Override -// public void setUp() throws Exception { -// super.setUp(); -// threadPool = new TestThreadPool("admission_controller_settings_test"); -// clusterService = new ClusterService( -// Settings.EMPTY, -// new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), -// threadPool -// ); -// } -// -// @Override -// public void tearDown() throws Exception { -// super.tearDown(); -// threadPool.shutdownNow(); -// } -// -// public void testSettingsExists() { -// Set> settings = ClusterSettings.BUILT_IN_CLUSTER_SETTINGS; -// assertTrue( -// "All the cpu based admission controller settings should be supported built in settings", -// settings.containsAll( -// Arrays.asList( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE, -// CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT, -// CPUBasedAdmissionControllerSettings.INDEXING_CPU_USAGE_LIMIT -// ) -// ) -// ); -// } -// -// public void testDefaultSettings() { -// CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( -// clusterService.getClusterSettings(), -// Settings.EMPTY -// ); -// long percent = 95; -// assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.DISABLED); -// assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), percent); -// assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), percent); -// assertEquals(cpuBasedAdmissionControllerSettings.getTransportActionsList(), Arrays.asList("indexing", "search")); -// } -// -// public void testGetConfiguredSettings() { -// long percent = 95; -// long indexingPercent = 85; -// Settings settings = Settings.builder() -// .put( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), -// AdmissionControlMode.ENFORCED.getMode() -// ) -// .put(CPUBasedAdmissionControllerSettings.INDEXING_CPU_USAGE_LIMIT.getKey(), indexingPercent) -// .build(); -// -// CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( -// clusterService.getClusterSettings(), -// settings -// ); -// assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); -// assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), percent); -// assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), indexingPercent); -// } -// -// public void testUpdateAfterGetDefaultSettings() { -// long percent = 95; -// long searchPercent = 80; -// CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( -// clusterService.getClusterSettings(), -// Settings.EMPTY -// ); -// Settings settings = Settings.builder() -// .put( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), -// AdmissionControlMode.ENFORCED.getMode() -// ) -// .put(CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT.getKey(), searchPercent) -// .build(); -// clusterService.getClusterSettings().applySettings(settings); -// assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); -// assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); -// assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), percent); -// } -// -// public void testUpdateAfterGetConfiguredSettings() { -// long percent = 95; -// long indexingPercent = 85; -// long searchPercent = 80; -// Settings settings = Settings.builder() -// .put( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), -// AdmissionControlMode.ENFORCED.getMode() -// ) -// .put(CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT.getKey(), searchPercent) -// .build(); -// -// CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( -// clusterService.getClusterSettings(), -// settings -// ); -// assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); -// assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); -// assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), percent); -// -// Settings updatedSettings = Settings.builder() -// .put( -// CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), -// AdmissionControlMode.MONITOR.getMode() -// ) -// .put(CPUBasedAdmissionControllerSettings.INDEXING_CPU_USAGE_LIMIT.getKey(), indexingPercent) -// .build(); -// clusterService.getClusterSettings().applySettings(updatedSettings); -// assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.MONITOR); -// assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); -// assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), indexingPercent); -// -// searchPercent = 70; -// -// updatedSettings = Settings.builder() -// .put(updatedSettings) -// .put(CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT.getKey(), searchPercent) -// .build(); -// clusterService.getClusterSettings().applySettings(updatedSettings); -// -// assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); -// assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), indexingPercent); -// } -// } +package org.opensearch.ratelimitting.admissioncontrol.settings; + +import org.opensearch.cluster.service.ClusterService; +import org.opensearch.common.settings.ClusterSettings; +import org.opensearch.common.settings.Setting; +import org.opensearch.common.settings.Settings; +import org.opensearch.ratelimitting.admissioncontrol.enums.AdmissionControlMode; +import org.opensearch.test.OpenSearchTestCase; +import org.opensearch.threadpool.TestThreadPool; +import org.opensearch.threadpool.ThreadPool; + +import java.util.Arrays; +import java.util.Set; + +public class CPUBasedAdmissionControlSettingsTests extends OpenSearchTestCase { + private ClusterService clusterService; + private ThreadPool threadPool; + + @Override + public void setUp() throws Exception { + super.setUp(); + threadPool = new TestThreadPool("admission_controller_settings_test"); + clusterService = new ClusterService( + Settings.EMPTY, + new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS), + threadPool + ); + } + + @Override + public void tearDown() throws Exception { + super.tearDown(); + threadPool.shutdownNow(); + } + + public void testSettingsExists() { + Set> settings = ClusterSettings.BUILT_IN_CLUSTER_SETTINGS; + assertTrue( + "All the cpu based admission controller settings should be supported built in settings", + settings.containsAll( + Arrays.asList( + CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE, + CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT, + CPUBasedAdmissionControllerSettings.INDEXING_CPU_USAGE_LIMIT + ) + ) + ); + } + + public void testDefaultSettings() { + CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( + clusterService.getClusterSettings(), + Settings.EMPTY + ); + long percent = 95; + assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.DISABLED); + assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), percent); + assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), percent); + assertEquals(cpuBasedAdmissionControllerSettings.getTransportActionsList(), Arrays.asList("indexing", "search")); + } + + public void testGetConfiguredSettings() { + long percent = 95; + long indexingPercent = 85; + Settings settings = Settings.builder() + .put( + CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), + AdmissionControlMode.ENFORCED.getMode() + ) + .put(CPUBasedAdmissionControllerSettings.INDEXING_CPU_USAGE_LIMIT.getKey(), indexingPercent) + .build(); + + CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( + clusterService.getClusterSettings(), + settings + ); + assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); + assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), percent); + assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), indexingPercent); + } + + public void testUpdateAfterGetDefaultSettings() { + long percent = 95; + long searchPercent = 80; + CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( + clusterService.getClusterSettings(), + Settings.EMPTY + ); + Settings settings = Settings.builder() + .put( + CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), + AdmissionControlMode.ENFORCED.getMode() + ) + .put(CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT.getKey(), searchPercent) + .build(); + clusterService.getClusterSettings().applySettings(settings); + assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); + assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); + assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), percent); + } + + public void testUpdateAfterGetConfiguredSettings() { + long percent = 95; + long indexingPercent = 85; + long searchPercent = 80; + Settings settings = Settings.builder() + .put( + CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), + AdmissionControlMode.ENFORCED.getMode() + ) + .put(CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT.getKey(), searchPercent) + .build(); + + CPUBasedAdmissionControllerSettings cpuBasedAdmissionControllerSettings = new CPUBasedAdmissionControllerSettings( + clusterService.getClusterSettings(), + settings + ); + assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.ENFORCED); + assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); + assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), percent); + + Settings updatedSettings = Settings.builder() + .put( + CPUBasedAdmissionControllerSettings.CPU_BASED_ADMISSION_CONTROLLER_TRANSPORT_LAYER_MODE.getKey(), + AdmissionControlMode.MONITOR.getMode() + ) + .put(CPUBasedAdmissionControllerSettings.INDEXING_CPU_USAGE_LIMIT.getKey(), indexingPercent) + .build(); + clusterService.getClusterSettings().applySettings(updatedSettings); + assertEquals(cpuBasedAdmissionControllerSettings.getTransportLayerAdmissionControllerMode(), AdmissionControlMode.MONITOR); + assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); + assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), indexingPercent); + + searchPercent = 70; + + updatedSettings = Settings.builder() + .put(updatedSettings) + .put(CPUBasedAdmissionControllerSettings.SEARCH_CPU_USAGE_LIMIT.getKey(), searchPercent) + .build(); + clusterService.getClusterSettings().applySettings(updatedSettings); + + assertEquals(cpuBasedAdmissionControllerSettings.getSearchCPULimit().longValue(), searchPercent); + assertEquals(cpuBasedAdmissionControllerSettings.getIndexingCPULimit().longValue(), indexingPercent); + } +}