Merge pull request #17740 from jasontedor/g1gc-tests
Pass test JVM arguments to test nodes
This commit is contained in:
commit
c9ada75e35
|
@ -19,7 +19,6 @@
|
||||||
package org.elasticsearch.gradle.test
|
package org.elasticsearch.gradle.test
|
||||||
|
|
||||||
import org.apache.tools.ant.taskdefs.condition.Os
|
import org.apache.tools.ant.taskdefs.condition.Os
|
||||||
import org.elasticsearch.gradle.VersionProperties
|
|
||||||
import org.gradle.api.InvalidUserDataException
|
import org.gradle.api.InvalidUserDataException
|
||||||
import org.gradle.api.Project
|
import org.gradle.api.Project
|
||||||
import org.gradle.api.Task
|
import org.gradle.api.Task
|
||||||
|
@ -129,11 +128,11 @@ class NodeInfo {
|
||||||
args.add("${esScript}")
|
args.add("${esScript}")
|
||||||
}
|
}
|
||||||
|
|
||||||
env = [
|
env = [ 'JAVA_HOME' : project.javaHome ]
|
||||||
'JAVA_HOME' : project.javaHome
|
|
||||||
]
|
|
||||||
args.addAll("-E", "es.node.portsfile=true")
|
args.addAll("-E", "es.node.portsfile=true")
|
||||||
env.put('ES_JAVA_OPTS', config.systemProperties.collect { key, value -> "-D${key}=${value}" }.join(" "))
|
String collectedSystemProperties = config.systemProperties.collect { key, value -> "-D${key}=${value}" }.join(" ")
|
||||||
|
String esJavaOpts = config.jvmArgs.isEmpty() ? collectedSystemProperties : collectedSystemProperties + " " + config.jvmArgs
|
||||||
|
env.put('ES_JAVA_OPTS', esJavaOpts)
|
||||||
for (Map.Entry<String, String> property : System.properties.entrySet()) {
|
for (Map.Entry<String, String> property : System.properties.entrySet()) {
|
||||||
if (property.getKey().startsWith('es.')) {
|
if (property.getKey().startsWith('es.')) {
|
||||||
args.add("-E")
|
args.add("-E")
|
||||||
|
|
|
@ -25,7 +25,7 @@ import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
class JavaVersion implements Comparable<JavaVersion> {
|
public class JavaVersion implements Comparable<JavaVersion> {
|
||||||
private final List<Integer> version;
|
private final List<Integer> version;
|
||||||
|
|
||||||
public List<Integer> getVersion() {
|
public List<Integer> getVersion() {
|
||||||
|
|
|
@ -48,8 +48,10 @@ public class ShardStateIT extends ESIntegTestCase {
|
||||||
indicesService.indexService(resolveIndex("test")).getShard(shard).failShard("simulated test failure", null);
|
indicesService.indexService(resolveIndex("test")).getShard(shard).failShard("simulated test failure", null);
|
||||||
|
|
||||||
logger.info("--> waiting for a yellow index");
|
logger.info("--> waiting for a yellow index");
|
||||||
assertBusy(() -> assertThat(client().admin().cluster().prepareHealth().get().getStatus(),
|
// JDK 9 type inference gets confused, so we have to help the
|
||||||
equalTo(ClusterHealthStatus.YELLOW)));
|
// type inference
|
||||||
|
assertBusy(((Runnable) () -> assertThat(client().admin().cluster().prepareHealth().get().getStatus(),
|
||||||
|
equalTo(ClusterHealthStatus.YELLOW))));
|
||||||
|
|
||||||
final long term0 = shard == 0 ? 2 : 1;
|
final long term0 = shard == 0 ? 2 : 1;
|
||||||
final long term1 = shard == 1 ? 2 : 1;
|
final long term1 = shard == 1 ? 2 : 1;
|
||||||
|
|
|
@ -0,0 +1,61 @@
|
||||||
|
/*
|
||||||
|
* Licensed to Elasticsearch under one or more contributor
|
||||||
|
* license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright
|
||||||
|
* ownership. Elasticsearch licenses this file to you under
|
||||||
|
* the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.elasticsearch.monitor.jvm;
|
||||||
|
|
||||||
|
import org.apache.lucene.util.Constants;
|
||||||
|
import org.elasticsearch.bootstrap.JavaVersion;
|
||||||
|
import org.elasticsearch.test.ESTestCase;
|
||||||
|
|
||||||
|
public class JvmInfoTests extends ESTestCase {
|
||||||
|
|
||||||
|
public void testUseG1GC() {
|
||||||
|
// if we are running on HotSpot, and the test JVM was started
|
||||||
|
// with UseG1GC, then JvmInfo should successfully report that
|
||||||
|
// G1GC is enabled
|
||||||
|
if (Constants.JVM_NAME.contains("HotSpot")) {
|
||||||
|
assertEquals(Boolean.toString(isG1GCEnabled()), JvmInfo.jvmInfo().useG1GC());
|
||||||
|
} else {
|
||||||
|
assertEquals("unknown", JvmInfo.jvmInfo().useG1GC());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isG1GCEnabled() {
|
||||||
|
final String argline = System.getProperty("tests.jvm.argline");
|
||||||
|
final boolean g1GCEnabled = flagIsEnabled(argline, "UseG1GC");
|
||||||
|
// for JDK 9 the default collector when no collector is specified is G1 GC
|
||||||
|
final boolean versionIsAtLeastJava9 = JavaVersion.current().compareTo(JavaVersion.parse("9")) >= 0;
|
||||||
|
final boolean noOtherCollectorSpecified =
|
||||||
|
argline == null ||
|
||||||
|
(!flagIsEnabled(argline, "UseParNewGC") &&
|
||||||
|
!flagIsEnabled(argline, "UseParallelGC") &&
|
||||||
|
!flagIsEnabled(argline, "UseParallelOldGC") &&
|
||||||
|
!flagIsEnabled(argline, "UseSerialGC") &&
|
||||||
|
!flagIsEnabled(argline, "UseConcMarkSweepGC"));
|
||||||
|
return g1GCEnabled || (versionIsAtLeastJava9 && noOtherCollectorSpecified);
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean flagIsEnabled(String argline, String flag) {
|
||||||
|
final boolean containsPositiveFlag = argline != null && argline.contains("-XX:+" + flag);
|
||||||
|
if (!containsPositiveFlag) return false;
|
||||||
|
final int index = argline.lastIndexOf(flag);
|
||||||
|
return argline.charAt(index - 1) == '+';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue