Build: Add mavenPlugin cluster configuration method (#30541)
This commit adds the ability to specify a plugin from maven for a test cluster to use. Currently, only local projects may be used as plugins, except when testing bwc, where the coordinates of the project are used. However, that assumes all projects always keep the same coordinates, or are even still plugins, which is no longer the case for x-pack. The full cluster and rolling restart tests are changed to use this new method when pulling x-pack versions before 6.3.0.
This commit is contained in:
parent
4c130a1054
commit
be8c094e8c
|
@ -147,7 +147,7 @@ class ClusterConfiguration {
|
||||||
// map from destination path, to source file
|
// map from destination path, to source file
|
||||||
Map<String, Object> extraConfigFiles = new HashMap<>()
|
Map<String, Object> extraConfigFiles = new HashMap<>()
|
||||||
|
|
||||||
LinkedHashMap<String, Project> plugins = new LinkedHashMap<>()
|
LinkedHashMap<String, Object> plugins = new LinkedHashMap<>()
|
||||||
|
|
||||||
List<Project> modules = new ArrayList<>()
|
List<Project> modules = new ArrayList<>()
|
||||||
|
|
||||||
|
@ -185,6 +185,11 @@ class ClusterConfiguration {
|
||||||
plugins.put(pluginProject.name, pluginProject)
|
plugins.put(pluginProject.name, pluginProject)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Input
|
||||||
|
void mavenPlugin(String name, String mavenCoords) {
|
||||||
|
plugins.put(name, mavenCoords)
|
||||||
|
}
|
||||||
|
|
||||||
/** Add a module to the cluster. The project must be an esplugin and have a single zip default artifact. */
|
/** Add a module to the cluster. The project must be an esplugin and have a single zip default artifact. */
|
||||||
@Input
|
@Input
|
||||||
void module(Project moduleProject) {
|
void module(Project moduleProject) {
|
||||||
|
|
|
@ -99,8 +99,8 @@ class ClusterFormationTasks {
|
||||||
// from mirrors using gradles built-in mechanism etc.
|
// from mirrors using gradles built-in mechanism etc.
|
||||||
|
|
||||||
configureDistributionDependency(project, config.distribution, bwcDistro, config.bwcVersion)
|
configureDistributionDependency(project, config.distribution, bwcDistro, config.bwcVersion)
|
||||||
for (Map.Entry<String, Project> entry : config.plugins.entrySet()) {
|
for (Map.Entry<String, Object> entry : config.plugins.entrySet()) {
|
||||||
configureBwcPluginDependency("${prefix}_elasticsearchBwcPlugins", project, entry.getValue(), bwcPlugins, config.bwcVersion)
|
configureBwcPluginDependency(project, entry.getValue(), bwcPlugins, config.bwcVersion)
|
||||||
}
|
}
|
||||||
bwcDistro.resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS)
|
bwcDistro.resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS)
|
||||||
bwcPlugins.resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS)
|
bwcPlugins.resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS)
|
||||||
|
@ -150,10 +150,15 @@ class ClusterFormationTasks {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Adds a dependency on a different version of the given plugin, which will be retrieved using gradle's dependency resolution */
|
/** Adds a dependency on a different version of the given plugin, which will be retrieved using gradle's dependency resolution */
|
||||||
static void configureBwcPluginDependency(String name, Project project, Project pluginProject, Configuration configuration, Version elasticsearchVersion) {
|
static void configureBwcPluginDependency(Project project, Object plugin, Configuration configuration, Version elasticsearchVersion) {
|
||||||
verifyProjectHasBuildPlugin(name, elasticsearchVersion, project, pluginProject)
|
if (plugin instanceof Project) {
|
||||||
final String pluginName = findPluginName(pluginProject)
|
Project pluginProject = (Project)plugin
|
||||||
project.dependencies.add(configuration.name, "org.elasticsearch.plugin:${pluginName}:${elasticsearchVersion}@zip")
|
verifyProjectHasBuildPlugin(configuration.name, elasticsearchVersion, project, pluginProject)
|
||||||
|
final String pluginName = findPluginName(pluginProject)
|
||||||
|
project.dependencies.add(configuration.name, "org.elasticsearch.plugin:${pluginName}:${elasticsearchVersion}@zip")
|
||||||
|
} else {
|
||||||
|
project.dependencies.add(configuration.name, "${plugin}@zip")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -210,9 +215,9 @@ class ClusterFormationTasks {
|
||||||
}
|
}
|
||||||
|
|
||||||
// install plugins
|
// install plugins
|
||||||
for (Map.Entry<String, Project> plugin : node.config.plugins.entrySet()) {
|
for (String pluginName : node.config.plugins.keySet()) {
|
||||||
String actionName = pluginTaskName('install', plugin.getKey(), 'Plugin')
|
String actionName = pluginTaskName('install', pluginName, 'Plugin')
|
||||||
setup = configureInstallPluginTask(taskName(prefix, node, actionName), project, setup, node, plugin.getValue(), prefix)
|
setup = configureInstallPluginTask(taskName(prefix, node, actionName), project, setup, node, pluginName, prefix)
|
||||||
}
|
}
|
||||||
|
|
||||||
// sets up any extra config files that need to be copied over to the ES instance;
|
// sets up any extra config files that need to be copied over to the ES instance;
|
||||||
|
@ -444,31 +449,40 @@ class ClusterFormationTasks {
|
||||||
Copy copyPlugins = project.tasks.create(name: name, type: Copy, dependsOn: setup)
|
Copy copyPlugins = project.tasks.create(name: name, type: Copy, dependsOn: setup)
|
||||||
|
|
||||||
List<FileCollection> pluginFiles = []
|
List<FileCollection> pluginFiles = []
|
||||||
for (Map.Entry<String, Project> plugin : node.config.plugins.entrySet()) {
|
for (Map.Entry<String, Object> plugin : node.config.plugins.entrySet()) {
|
||||||
|
|
||||||
Project pluginProject = plugin.getValue()
|
String configurationName = pluginConfigurationName(prefix, plugin.key)
|
||||||
verifyProjectHasBuildPlugin(name, node.nodeVersion, project, pluginProject)
|
|
||||||
String configurationName = pluginConfigurationName(prefix, pluginProject)
|
|
||||||
Configuration configuration = project.configurations.findByName(configurationName)
|
Configuration configuration = project.configurations.findByName(configurationName)
|
||||||
if (configuration == null) {
|
if (configuration == null) {
|
||||||
configuration = project.configurations.create(configurationName)
|
configuration = project.configurations.create(configurationName)
|
||||||
}
|
}
|
||||||
project.dependencies.add(configurationName, project.dependencies.project(path: pluginProject.path, configuration: 'zip'))
|
|
||||||
setup.dependsOn(pluginProject.tasks.bundlePlugin)
|
|
||||||
|
|
||||||
// also allow rest tests to use the rest spec from the plugin
|
if (plugin.getValue() instanceof Project) {
|
||||||
String copyRestSpecTaskName = pluginTaskName('copy', plugin.getKey(), 'PluginRestSpec')
|
Project pluginProject = plugin.getValue()
|
||||||
Copy copyRestSpec = project.tasks.findByName(copyRestSpecTaskName)
|
verifyProjectHasBuildPlugin(name, node.nodeVersion, project, pluginProject)
|
||||||
for (File resourceDir : pluginProject.sourceSets.test.resources.srcDirs) {
|
|
||||||
File restApiDir = new File(resourceDir, 'rest-api-spec/api')
|
project.dependencies.add(configurationName, project.dependencies.project(path: pluginProject.path, configuration: 'zip'))
|
||||||
if (restApiDir.exists() == false) continue
|
setup.dependsOn(pluginProject.tasks.bundlePlugin)
|
||||||
if (copyRestSpec == null) {
|
|
||||||
copyRestSpec = project.tasks.create(name: copyRestSpecTaskName, type: Copy)
|
// also allow rest tests to use the rest spec from the plugin
|
||||||
copyPlugins.dependsOn(copyRestSpec)
|
String copyRestSpecTaskName = pluginTaskName('copy', plugin.getKey(), 'PluginRestSpec')
|
||||||
copyRestSpec.into(project.sourceSets.test.output.resourcesDir)
|
Copy copyRestSpec = project.tasks.findByName(copyRestSpecTaskName)
|
||||||
|
for (File resourceDir : pluginProject.sourceSets.test.resources.srcDirs) {
|
||||||
|
File restApiDir = new File(resourceDir, 'rest-api-spec/api')
|
||||||
|
if (restApiDir.exists() == false) continue
|
||||||
|
if (copyRestSpec == null) {
|
||||||
|
copyRestSpec = project.tasks.create(name: copyRestSpecTaskName, type: Copy)
|
||||||
|
copyPlugins.dependsOn(copyRestSpec)
|
||||||
|
copyRestSpec.into(project.sourceSets.test.output.resourcesDir)
|
||||||
|
}
|
||||||
|
copyRestSpec.from(resourceDir).include('rest-api-spec/api/**')
|
||||||
}
|
}
|
||||||
copyRestSpec.from(resourceDir).include('rest-api-spec/api/**')
|
} else {
|
||||||
|
project.dependencies.add(configurationName, "${plugin.getValue()}@zip")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
pluginFiles.add(configuration)
|
pluginFiles.add(configuration)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -477,32 +491,37 @@ class ClusterFormationTasks {
|
||||||
return copyPlugins
|
return copyPlugins
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String pluginConfigurationName(final String prefix, final Project project) {
|
private static String pluginConfigurationName(final String prefix, final String name) {
|
||||||
return "_plugin_${prefix}_${project.path}".replace(':', '_')
|
return "_plugin_${prefix}_${name}".replace(':', '_')
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String pluginBwcConfigurationName(final String prefix, final Project project) {
|
private static String pluginBwcConfigurationName(final String prefix, final String name) {
|
||||||
return "_plugin_bwc_${prefix}_${project.path}".replace(':', '_')
|
return "_plugin_bwc_${prefix}_${name}".replace(':', '_')
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Configures task to copy a plugin based on a zip file resolved using dependencies for an older version */
|
/** Configures task to copy a plugin based on a zip file resolved using dependencies for an older version */
|
||||||
static Task configureCopyBwcPluginsTask(String name, Project project, Task setup, NodeInfo node, String prefix) {
|
static Task configureCopyBwcPluginsTask(String name, Project project, Task setup, NodeInfo node, String prefix) {
|
||||||
Configuration bwcPlugins = project.configurations.getByName("${prefix}_elasticsearchBwcPlugins")
|
Configuration bwcPlugins = project.configurations.getByName("${prefix}_elasticsearchBwcPlugins")
|
||||||
for (Map.Entry<String, Project> plugin : node.config.plugins.entrySet()) {
|
for (Map.Entry<String, Object> plugin : node.config.plugins.entrySet()) {
|
||||||
Project pluginProject = plugin.getValue()
|
String configurationName = pluginBwcConfigurationName(prefix, plugin.key)
|
||||||
verifyProjectHasBuildPlugin(name, node.nodeVersion, project, pluginProject)
|
|
||||||
String configurationName = pluginBwcConfigurationName(prefix, pluginProject)
|
|
||||||
Configuration configuration = project.configurations.findByName(configurationName)
|
Configuration configuration = project.configurations.findByName(configurationName)
|
||||||
if (configuration == null) {
|
if (configuration == null) {
|
||||||
configuration = project.configurations.create(configurationName)
|
configuration = project.configurations.create(configurationName)
|
||||||
}
|
}
|
||||||
|
|
||||||
final String depName = findPluginName(pluginProject)
|
if (plugin.getValue() instanceof Project) {
|
||||||
|
Project pluginProject = plugin.getValue()
|
||||||
|
verifyProjectHasBuildPlugin(name, node.nodeVersion, project, pluginProject)
|
||||||
|
|
||||||
Dependency dep = bwcPlugins.dependencies.find {
|
final String depName = findPluginName(pluginProject)
|
||||||
it.name == depName
|
|
||||||
|
Dependency dep = bwcPlugins.dependencies.find {
|
||||||
|
it.name == depName
|
||||||
|
}
|
||||||
|
configuration.dependencies.add(dep)
|
||||||
|
} else {
|
||||||
|
project.dependencies.add(configurationName, "${plugin.getValue()}@zip")
|
||||||
}
|
}
|
||||||
configuration.dependencies.add(dep)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Copy copyPlugins = project.tasks.create(name: name, type: Copy, dependsOn: setup) {
|
Copy copyPlugins = project.tasks.create(name: name, type: Copy, dependsOn: setup) {
|
||||||
|
@ -527,12 +546,12 @@ class ClusterFormationTasks {
|
||||||
return installModule
|
return installModule
|
||||||
}
|
}
|
||||||
|
|
||||||
static Task configureInstallPluginTask(String name, Project project, Task setup, NodeInfo node, Project plugin, String prefix) {
|
static Task configureInstallPluginTask(String name, Project project, Task setup, NodeInfo node, String pluginName, String prefix) {
|
||||||
final FileCollection pluginZip;
|
final FileCollection pluginZip;
|
||||||
if (node.nodeVersion != VersionProperties.elasticsearch) {
|
if (node.nodeVersion != VersionProperties.elasticsearch) {
|
||||||
pluginZip = project.configurations.getByName(pluginBwcConfigurationName(prefix, plugin))
|
pluginZip = project.configurations.getByName(pluginBwcConfigurationName(prefix, pluginName))
|
||||||
} else {
|
} else {
|
||||||
pluginZip = project.configurations.getByName(pluginConfigurationName(prefix, plugin))
|
pluginZip = project.configurations.getByName(pluginConfigurationName(prefix, pluginName))
|
||||||
}
|
}
|
||||||
// delay reading the file location until execution time by wrapping in a closure within a GString
|
// delay reading the file location until execution time by wrapping in a closure within a GString
|
||||||
final Object file = "${-> new File(node.pluginsTmpDir, pluginZip.singleFile.getName()).toURI().toURL().toString()}"
|
final Object file = "${-> new File(node.pluginsTmpDir, pluginZip.singleFile.getName()).toURI().toURL().toString()}"
|
||||||
|
|
|
@ -141,7 +141,7 @@ subprojects {
|
||||||
configure(extensions.findByName("${baseName}#oldClusterTestCluster")) {
|
configure(extensions.findByName("${baseName}#oldClusterTestCluster")) {
|
||||||
dependsOn copyTestNodeKeystore
|
dependsOn copyTestNodeKeystore
|
||||||
if (version.before('6.3.0')) {
|
if (version.before('6.3.0')) {
|
||||||
plugin xpackProject('plugin').path
|
mavenPlugin 'x-pack', "org.elasticsearch.plugin:x-pack:${version}"
|
||||||
}
|
}
|
||||||
bwcVersion = version
|
bwcVersion = version
|
||||||
numBwcNodes = 2
|
numBwcNodes = 2
|
||||||
|
|
|
@ -82,7 +82,7 @@ for (Version version : bwcVersions.wireCompatible) {
|
||||||
|
|
||||||
configure(extensions.findByName("${baseName}#oldClusterTestCluster")) {
|
configure(extensions.findByName("${baseName}#oldClusterTestCluster")) {
|
||||||
if (version.before('6.3.0')) {
|
if (version.before('6.3.0')) {
|
||||||
plugin xpackProject('plugin').path
|
mavenPlugin 'x-pack', "org.elasticsearch.plugin:x-pack:${version}"
|
||||||
}
|
}
|
||||||
bwcVersion = version
|
bwcVersion = version
|
||||||
numBwcNodes = 2
|
numBwcNodes = 2
|
||||||
|
|
|
@ -123,7 +123,7 @@ subprojects {
|
||||||
configure(extensions.findByName("${baseName}#oldClusterTestCluster")) {
|
configure(extensions.findByName("${baseName}#oldClusterTestCluster")) {
|
||||||
dependsOn copyTestNodeKeystore
|
dependsOn copyTestNodeKeystore
|
||||||
if (version.before('6.3.0')) {
|
if (version.before('6.3.0')) {
|
||||||
plugin xpackProject('plugin').path
|
mavenPlugin 'x-pack', "org.elasticsearch.plugin:x-pack:${version}"
|
||||||
}
|
}
|
||||||
String usersCli = version.before('6.3.0') ? 'bin/x-pack/users' : 'bin/elasticsearch-users'
|
String usersCli = version.before('6.3.0') ? 'bin/x-pack/users' : 'bin/elasticsearch-users'
|
||||||
setupCommand 'setupTestUser', usersCli, 'useradd', 'test_user', '-p', 'x-pack-test-password', '-r', 'superuser'
|
setupCommand 'setupTestUser', usersCli, 'useradd', 'test_user', '-p', 'x-pack-test-password', '-r', 'superuser'
|
||||||
|
|
Loading…
Reference in New Issue