Test: don't modify defaultConfig on upgrade (#55560) (#55599)

Backport: 58ec9c3
This commit is contained in:
Stuart Tettemer 2020-04-22 11:07:27 -06:00 committed by GitHub
parent 3504755f44
commit 41748f02a5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 22 additions and 21 deletions

View File

@ -1073,43 +1073,44 @@ public class ElasticsearchNode implements TestClusterConfiguration {
private void createConfiguration() { private void createConfiguration() {
String nodeName = nameCustomization.apply(safeName(name)); String nodeName = nameCustomization.apply(safeName(name));
Map<String, String> baseConfig = new HashMap<>(defaultConfig);
if (nodeName != null) { if (nodeName != null) {
defaultConfig.put("node.name", nodeName); baseConfig.put("node.name", nodeName);
} }
defaultConfig.put("path.repo", confPathRepo.toAbsolutePath().toString()); baseConfig.put("path.repo", confPathRepo.toAbsolutePath().toString());
defaultConfig.put("path.data", confPathData.toAbsolutePath().toString()); baseConfig.put("path.data", confPathData.toAbsolutePath().toString());
defaultConfig.put("path.logs", confPathLogs.toAbsolutePath().toString()); baseConfig.put("path.logs", confPathLogs.toAbsolutePath().toString());
defaultConfig.put("path.shared_data", workingDir.resolve("sharedData").toString()); baseConfig.put("path.shared_data", workingDir.resolve("sharedData").toString());
defaultConfig.put("node.attr.testattr", "test"); baseConfig.put("node.attr.testattr", "test");
defaultConfig.put("node.portsfile", "true"); baseConfig.put("node.portsfile", "true");
defaultConfig.put("http.port", httpPort); baseConfig.put("http.port", httpPort);
if (getVersion().onOrAfter(Version.fromString("6.7.0"))) { if (getVersion().onOrAfter(Version.fromString("6.7.0"))) {
defaultConfig.put("transport.port", transportPort); baseConfig.put("transport.port", transportPort);
} else { } else {
defaultConfig.put("transport.tcp.port", transportPort); baseConfig.put("transport.tcp.port", transportPort);
} }
// Default the watermarks to absurdly low to prevent the tests from failing on nodes without enough disk space // Default the watermarks to absurdly low to prevent the tests from failing on nodes without enough disk space
defaultConfig.put("cluster.routing.allocation.disk.watermark.low", "1b"); baseConfig.put("cluster.routing.allocation.disk.watermark.low", "1b");
defaultConfig.put("cluster.routing.allocation.disk.watermark.high", "1b"); baseConfig.put("cluster.routing.allocation.disk.watermark.high", "1b");
// increase script compilation limit since tests can rapid-fire script compilations // increase script compilation limit since tests can rapid-fire script compilations
defaultConfig.put("script.max_compilations_rate", "2048/1m"); baseConfig.put("script.max_compilations_rate", "2048/1m");
if (getVersion().getMajor() >= 6) { if (getVersion().getMajor() >= 6) {
defaultConfig.put("cluster.routing.allocation.disk.watermark.flood_stage", "1b"); baseConfig.put("cluster.routing.allocation.disk.watermark.flood_stage", "1b");
} }
// Temporarily disable the real memory usage circuit breaker. It depends on real memory usage which we have no full control // Temporarily disable the real memory usage circuit breaker. It depends on real memory usage which we have no full control
// over and the REST client will not retry on circuit breaking exceptions yet (see #31986 for details). Once the REST client // over and the REST client will not retry on circuit breaking exceptions yet (see #31986 for details). Once the REST client
// can retry on circuit breaking exceptions, we can revert again to the default configuration. // can retry on circuit breaking exceptions, we can revert again to the default configuration.
if (getVersion().getMajor() >= 7) { if (getVersion().getMajor() >= 7) {
defaultConfig.put("indices.breaker.total.use_real_memory", "false"); baseConfig.put("indices.breaker.total.use_real_memory", "false");
} }
// Don't wait for state, just start up quickly. This will also allow new and old nodes in the BWC case to become the master // Don't wait for state, just start up quickly. This will also allow new and old nodes in the BWC case to become the master
defaultConfig.put("discovery.initial_state_timeout", "0s"); baseConfig.put("discovery.initial_state_timeout", "0s");
// TODO: Remove these once https://github.com/elastic/elasticsearch/issues/46091 is fixed // TODO: Remove these once https://github.com/elastic/elasticsearch/issues/46091 is fixed
defaultConfig.put("logger.org.elasticsearch.action.support.master", "DEBUG"); baseConfig.put("logger.org.elasticsearch.action.support.master", "DEBUG");
defaultConfig.put("logger.org.elasticsearch.cluster.coordination", "DEBUG"); baseConfig.put("logger.org.elasticsearch.cluster.coordination", "DEBUG");
HashSet<String> overriden = new HashSet<>(defaultConfig.keySet()); HashSet<String> overriden = new HashSet<>(baseConfig.keySet());
overriden.retainAll(settings.keySet()); overriden.retainAll(settings.keySet());
overriden.removeAll(OVERRIDABLE_SETTINGS); overriden.removeAll(OVERRIDABLE_SETTINGS);
if (overriden.isEmpty() == false) { if (overriden.isEmpty() == false) {
@ -1118,12 +1119,12 @@ public class ElasticsearchNode implements TestClusterConfiguration {
); );
} }
// Make sure no duplicate config keys // Make sure no duplicate config keys
settings.keySet().stream().filter(OVERRIDABLE_SETTINGS::contains).forEach(defaultConfig::remove); settings.keySet().stream().filter(OVERRIDABLE_SETTINGS::contains).forEach(baseConfig::remove);
try { try {
Files.write( Files.write(
configFile, configFile,
Stream.concat(settings.entrySet().stream(), defaultConfig.entrySet().stream()) Stream.concat(settings.entrySet().stream(), baseConfig.entrySet().stream())
.map(entry -> entry.getKey() + ": " + entry.getValue()) .map(entry -> entry.getKey() + ": " + entry.getValue())
.collect(Collectors.joining("\n")) .collect(Collectors.joining("\n"))
.getBytes(StandardCharsets.UTF_8), .getBytes(StandardCharsets.UTF_8),