Fix secure repository-hdfs tests on JDK 9

The secure repository-hdfs tests fail on JDK 9 because some Hadoop code
reaches into sun.security.krb5. This commit adds the necessary flags to
open the java.security.jgss module. Note that these flags are actually
needed at runtime as well when using secure repository-hdfs. For now we
will punt on how best to help users obtain this when running on JDK 9
with this plugin.

Relates #25205
This commit is contained in:
Jason Tedor 2017-06-13 13:26:48 -04:00 committed by GitHub
parent a7dafdaa05
commit 8de6f4e608
1 changed files with 22 additions and 5 deletions

View File

@ -122,10 +122,18 @@ task secureHdfsFixture(type: org.elasticsearch.gradle.test.AntFixture) {
Path keytabPath = project(':test:fixtures:krb5kdc-fixture').buildDir.toPath().resolve("keytabs").resolve("hdfs_hdfs.build.elastic.co.keytab") Path keytabPath = project(':test:fixtures:krb5kdc-fixture').buildDir.toPath().resolve("keytabs").resolve("hdfs_hdfs.build.elastic.co.keytab")
Path krb5Config = project(':test:fixtures:krb5kdc-fixture').buildDir.toPath().resolve("conf").resolve("krb5.conf") Path krb5Config = project(':test:fixtures:krb5kdc-fixture').buildDir.toPath().resolve("conf").resolve("krb5.conf")
args "-Djava.security.krb5.conf=${krb5Config}", 'hdfs.MiniHDFS', final List<String> miniHDFSArgs = ["-Djava.security.krb5.conf=${krb5Config}"]
baseDir,
"hdfs/hdfs.build.elastic.co@${realm}", if (project.rootProject.ext.javaVersion == JavaVersion.VERSION_1_9) {
"${keytabPath}" miniHDFSArgs.add('--add-opens=java.security.jgss/sun.security.krb5=ALL-UNNAMED')
}
miniHDFSArgs.add('hdfs.MiniHDFS')
miniHDFSArgs.add(baseDir)
miniHDFSArgs.add("hdfs/hdfs.build.elastic.co@${realm}")
miniHDFSArgs.add("${keytabPath}")
args miniHDFSArgs.toArray()
} }
boolean fixtureSupported = false boolean fixtureSupported = false
@ -170,10 +178,19 @@ project.afterEvaluate {
project.integTestSecureCluster.dependsOn(project.bundlePlugin) project.integTestSecureCluster.dependsOn(project.bundlePlugin)
project.integTestSecure.clusterConfig.plugin(project.path) project.integTestSecure.clusterConfig.plugin(project.path)
project.integTestSecure.clusterConfig.extraConfigFile("repository-hdfs/krb5.keytab", "${elasticsearchKT}") project.integTestSecure.clusterConfig.extraConfigFile("repository-hdfs/krb5.keytab", "${elasticsearchKT}")
project.integTestSecure.clusterConfig.jvmArgs = "-Xms" + System.getProperty('tests.heap.size', '512m') +
final String baseJvmArgs = "-Xms" + System.getProperty('tests.heap.size', '512m') +
" " + "-Xmx" + System.getProperty('tests.heap.size', '512m') + " " + "-Xmx" + System.getProperty('tests.heap.size', '512m') +
" " + "-Djava.security.krb5.conf=${krb5conf}" + " " + "-Djava.security.krb5.conf=${krb5conf}" +
" " + System.getProperty('tests.jvm.argline', '') " " + System.getProperty('tests.jvm.argline', '')
final String jvmArgs
if (project.rootProject.ext.javaVersion == JavaVersion.VERSION_1_9) {
jvmArgs = baseJvmArgs + " " + '--add-opens=java.security.jgss/sun.security.krb5=ALL-UNNAMED'
} else {
jvmArgs = baseJvmArgs
}
project.integTestSecure.clusterConfig.jvmArgs = jvmArgs
} }
RestIntegTestTask integTestSecure = project.tasks.create('integTestSecure', RestIntegTestTask.class) { RestIntegTestTask integTestSecure = project.tasks.create('integTestSecure', RestIntegTestTask.class) {