|
26 | 26 | import java.util.Collections;
|
27 | 27 | import java.util.HashMap;
|
28 | 28 | import java.util.HashSet;
|
| 29 | +import java.util.Iterator; |
29 | 30 | import java.util.LinkedHashSet;
|
30 | 31 | import java.util.List;
|
31 | 32 | import java.util.Map;
|
| 33 | +import java.util.Objects; |
32 | 34 | import java.util.Set;
|
33 | 35 | import java.util.concurrent.atomic.AtomicInteger;
|
34 | 36 | import java.util.concurrent.atomic.AtomicReference;
|
@@ -259,6 +261,46 @@ public void testDependentSettingsWithFallback() {
|
259 | 261 | service.validate(Settings.builder().put("fallback.test.name", "test").put("foo.test.bar", 7).build(), true);
|
260 | 262 | }
|
261 | 263 |
|
| 264 | + public void testValidatorWithDependencies() { |
| 265 | + final boolean nodeSetting = randomBoolean(); |
| 266 | + final String prefix = nodeSetting ? "" : "index."; |
| 267 | + final Property scopeProperty = nodeSetting ? Property.NodeScope : Property.IndexScope; |
| 268 | + final Setting<String> baseSetting = Setting.simpleString(prefix + "foo.base", Property.Dynamic, scopeProperty); |
| 269 | + final Setting.Validator<String> validator = new Setting.Validator<String>() { |
| 270 | + @Override |
| 271 | + public void validate(String value) { |
| 272 | + } |
| 273 | + |
| 274 | + @Override |
| 275 | + public void validate(String value, Map<Setting<?>, Object> settings, boolean isPresent) { |
| 276 | + if (Objects.equals(value, settings.get(baseSetting)) == false) { |
| 277 | + throw new IllegalArgumentException("must have same value"); |
| 278 | + } |
| 279 | + } |
| 280 | + |
| 281 | + @Override |
| 282 | + public Iterator<Setting<?>> settings() { |
| 283 | + return List.<Setting<?>>of(baseSetting).iterator(); |
| 284 | + } |
| 285 | + }; |
| 286 | + final Setting<String> dependingSetting = Setting.simpleString(prefix + "foo.depending", validator, scopeProperty); |
| 287 | + |
| 288 | + final AbstractScopedSettings service = nodeSetting ? new ClusterSettings(Settings.EMPTY, Set.of(baseSetting, dependingSetting)) : |
| 289 | + new IndexScopedSettings(Settings.EMPTY, Set.of(baseSetting, dependingSetting)); |
| 290 | + |
| 291 | + service.validate(Settings.builder().put(baseSetting.getKey(), "1").put(dependingSetting.getKey(), 1).build(), true); |
| 292 | + service.validate(Settings.builder().put(dependingSetting.getKey(), "1").build(), false); |
| 293 | + final IllegalArgumentException e = expectThrows( |
| 294 | + IllegalArgumentException.class, |
| 295 | + () -> service.validate(Settings.builder().put(dependingSetting.getKey(), "1").build(), true)); |
| 296 | + assertThat(e.getMessage(), equalTo("must have same value")); |
| 297 | + |
| 298 | + final IllegalArgumentException e2 = expectThrows( |
| 299 | + IllegalArgumentException.class, |
| 300 | + () -> service.validate(Settings.builder().put(baseSetting.getKey(), "2").put(dependingSetting.getKey(), "1").build(), true)); |
| 301 | + assertThat(e2.getMessage(), equalTo("must have same value")); |
| 302 | + } |
| 303 | + |
262 | 304 | public void testTupleAffixUpdateConsumer() {
|
263 | 305 | String prefix = randomAlphaOfLength(3) + "foo.";
|
264 | 306 | String intSuffix = randomAlphaOfLength(3);
|
|
0 commit comments