118 lines
3.8 KiB
Groovy
118 lines
3.8 KiB
Groovy
/*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* The OpenSearch Contributors require contributions made to
|
|
* this file be licensed under the Apache-2.0 license or a
|
|
* compatible open source license.
|
|
*
|
|
* Modifications Copyright OpenSearch Contributors. See
|
|
* GitHub history for details.
|
|
*/
|
|
|
|
/*
|
|
* 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.
|
|
*/
|
|
|
|
|
|
import org.opensearch.gradle.Version
|
|
import org.opensearch.gradle.info.BuildParams
|
|
import org.opensearch.gradle.testclusters.StandaloneRestIntegTestTask
|
|
|
|
apply plugin: 'opensearch.testclusters'
|
|
apply plugin: 'opensearch.standalone-test'
|
|
apply from : "$rootDir/gradle/bwc-test.gradle"
|
|
|
|
for (Version bwcVersion : BuildParams.bwcVersions.indexCompatible) {
|
|
if (bwcVersion.before('6.3.0')) {
|
|
// explicitly running restart on the current node does not work in step 2
|
|
// below when plugins are installed, which is the case for some plugins
|
|
// prior to 6.3.0
|
|
continue
|
|
}
|
|
String baseName = "v${bwcVersion}"
|
|
|
|
testClusters {
|
|
"${baseName}" {
|
|
versions = [bwcVersion.toString(), project.version]
|
|
numberOfNodes = 2
|
|
setting 'http.content_type.required', 'true'
|
|
}
|
|
}
|
|
|
|
tasks.register("${baseName}#Step1OldClusterTest", StandaloneRestIntegTestTask) {
|
|
useCluster testClusters."${baseName}"
|
|
mustRunAfter(precommit)
|
|
systemProperty 'tests.test_step', 'step1'
|
|
systemProperty 'tests.is_old_cluster', 'true'
|
|
}
|
|
|
|
tasks.register("${baseName}#Step2OldClusterTest", StandaloneRestIntegTestTask) {
|
|
useCluster testClusters."${baseName}"
|
|
dependsOn "${baseName}#Step1OldClusterTest"
|
|
doFirst {
|
|
testClusters."${baseName}".fullRestart()
|
|
}
|
|
systemProperty 'tests.test_step', 'step2'
|
|
systemProperty 'tests.is_old_cluster', 'true'
|
|
}
|
|
|
|
tasks.register("${baseName}#Step3NewClusterTest", StandaloneRestIntegTestTask) {
|
|
useCluster testClusters."${baseName}"
|
|
dependsOn "${baseName}#Step2OldClusterTest"
|
|
doFirst {
|
|
testClusters."${baseName}".goToNextVersion()
|
|
}
|
|
systemProperty 'tests.test_step', 'step3'
|
|
systemProperty 'tests.is_old_cluster', 'false'
|
|
}
|
|
|
|
tasks.register("${baseName}#Step4NewClusterTest", StandaloneRestIntegTestTask) {
|
|
useCluster testClusters."${baseName}"
|
|
dependsOn "${baseName}#Step3NewClusterTest"
|
|
doFirst {
|
|
testClusters."${baseName}".fullRestart()
|
|
}
|
|
systemProperty 'tests.test_step', 'step4'
|
|
systemProperty 'tests.is_old_cluster', 'false'
|
|
}
|
|
|
|
String oldVersion = bwcVersion.toString().minus("-SNAPSHOT")
|
|
tasks.matching { it.name.startsWith(baseName) && it.name.endsWith("ClusterTest") }.configureEach {
|
|
it.systemProperty 'tests.old_cluster_version', oldVersion
|
|
it.nonInputProperties.systemProperty('tests.rest.cluster', "${-> testClusters."${baseName}".allHttpSocketURI.join(",")}")
|
|
it.nonInputProperties.systemProperty('tests.clustername', "${-> testClusters."${baseName}".getName()}")
|
|
}
|
|
|
|
tasks.register(bwcTaskName(bwcVersion)) {
|
|
dependsOn tasks.named("${baseName}#Step4NewClusterTest")
|
|
}
|
|
}
|
|
|
|
configurations {
|
|
testArtifacts.extendsFrom testRuntime
|
|
}
|
|
|
|
task testJar(type: Jar) {
|
|
appendix 'test'
|
|
from sourceSets.test.output
|
|
}
|
|
|
|
artifacts {
|
|
testArtifacts testJar
|
|
}
|