mirror of
https://github.com/honeymoose/OpenSearch.git
synced 2025-03-03 09:29:11 +00:00
This change adds back the multi node smoke test, as well as making the cluster formation for any test allow multiple nodes. The main changes in cluster formation are abstracting out the node specific configuration to a helper struct, as well as making a single wait task that waits for all nodes after their start tasks have run. The output on failure was also improved to log which node's info is being printed.
80 lines
2.4 KiB
Groovy
80 lines
2.4 KiB
Groovy
rootProject.name = 'elasticsearch'
|
|
|
|
List projects = [
|
|
'rest-api-spec',
|
|
'core',
|
|
'distribution:zip',
|
|
'distribution:tar',
|
|
'distribution:deb',
|
|
'distribution:rpm',
|
|
'test-framework',
|
|
'plugins:analysis-icu',
|
|
'plugins:analysis-kuromoji',
|
|
'plugins:analysis-phonetic',
|
|
'plugins:analysis-smartcn',
|
|
'plugins:analysis-stempel',
|
|
'plugins:delete-by-query',
|
|
'plugins:discovery-azure',
|
|
'plugins:discovery-ec2',
|
|
'plugins:discovery-gce',
|
|
'plugins:discovery-multicast',
|
|
'plugins:lang-expression',
|
|
'plugins:lang-groovy',
|
|
'plugins:lang-javascript',
|
|
'plugins:lang-python',
|
|
'plugins:mapper-attachments',
|
|
'plugins:mapper-murmur3',
|
|
'plugins:mapper-size',
|
|
'plugins:repository-azure',
|
|
'plugins:repository-s3',
|
|
'plugins:jvm-example',
|
|
'plugins:site-example',
|
|
'plugins:store-smb',
|
|
'qa:evil-tests',
|
|
'qa:smoke-test-client',
|
|
'qa:smoke-test-multinode',
|
|
'qa:smoke-test-plugins',
|
|
'qa:vagrant',
|
|
]
|
|
|
|
boolean isEclipse = System.getProperty("eclipse.launcher") != null || gradle.startParameter.taskNames.contains('eclipse') || gradle.startParameter.taskNames.contains('cleanEclipse')
|
|
if (isEclipse) {
|
|
// eclipse cannot handle an intermediate dependency between main and test, so we must create separate projects
|
|
// for core-src and core-tests
|
|
projects << 'core-tests'
|
|
}
|
|
|
|
include projects.toArray(new String[0])
|
|
|
|
if (isEclipse) {
|
|
project(":core").projectDir = new File(rootProject.projectDir, 'core/src/main')
|
|
project(":core").buildFileName = 'eclipse-build.gradle'
|
|
project(":core-tests").projectDir = new File(rootProject.projectDir, 'core/src/test')
|
|
project(":core-tests").buildFileName = 'eclipse-build.gradle'
|
|
}
|
|
|
|
/**
|
|
* Iterates over sub directories, looking for build.gradle, and adds a project if found
|
|
* for that dir with the given path prefix. Note that this requires each level
|
|
* of the dir hiearchy to have a build.gradle. Otherwise we would have to iterate
|
|
* all files/directories in the source tree to find all projects.
|
|
*/
|
|
void addSubProjects(String path, File dir) {
|
|
if (dir.isDirectory() == false) return;
|
|
if (new File(dir, 'build.gradle').exists() == false) return;
|
|
|
|
String projectName = "${path}:${dir.name}"
|
|
include projectName
|
|
project(projectName).projectDir = dir
|
|
|
|
for (File subdir : dir.listFiles()) {
|
|
addSubProjects(projectName, subdir)
|
|
}
|
|
}
|
|
|
|
File extraPlugins = new File(rootProject.projectDir, 'extra-plugins')
|
|
for (File extraPluginDir : extraPlugins.listFiles()) {
|
|
addSubProjects('', extraPluginDir)
|
|
}
|
|
|