mirror of
https://github.com/honeymoose/OpenSearch.git
synced 2025-02-06 04:58:50 +00:00
39fa1c4df0
This commit adds compatibility testing of our JDBC driver against different Elasticsearch versions. Although we are really testing the forwards compatibility nature of the JDBC driver we model the testing the same as we do existing BWC tests, that is, with the current branch fetching the earlier versions of the artifact that is to be tested. In this case, that's the JDBC driver itself. Because the tests include the JDBC driver jar on it's classpath we had to change the packaging of the driver jar in order to avoid jarhell and other conflicting dependency issues when using an old JDBC driver with later branches. For this we simply relocate all driver dependencies in the shadow jar under a "shadowed" package. This allows the JDBC driver to use the correct version of Elasticsearch libs classes, while the tests themselves use their versions. Since this required a change to the driver jar compatibility testing can only go back as far as that version which at the time of this commit is 7.8.1.
304 lines
11 KiB
Groovy
304 lines
11 KiB
Groovy
/*
|
|
* 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.gradle.internal.jvm.Jvm
|
|
import org.gradle.util.GradleVersion
|
|
|
|
plugins {
|
|
id 'java-gradle-plugin'
|
|
id 'groovy'
|
|
id 'java-test-fixtures'
|
|
}
|
|
|
|
group = 'org.elasticsearch.gradle'
|
|
|
|
String minimumGradleVersion = file('src/main/resources/minimumGradleVersion').text.trim()
|
|
if (GradleVersion.current() < GradleVersion.version(minimumGradleVersion)) {
|
|
throw new GradleException("Gradle ${minimumGradleVersion}+ is required to build elasticsearch")
|
|
}
|
|
|
|
if (project == rootProject) {
|
|
// change the build dir used during build init, so that doing a clean
|
|
// won't wipe out the buildscript jar
|
|
buildDir = 'build-bootstrap'
|
|
}
|
|
|
|
/*****************************************************************************
|
|
* Propagating version.properties to the rest of the build *
|
|
*****************************************************************************/
|
|
|
|
// we update the version property to reflect if we are building a snapshot or a release build
|
|
// we write this back out below to load it in the Build.java which will be shown in rest main action
|
|
// to indicate this being a snapshot build or a release build.
|
|
Properties props = VersionPropertiesLoader.loadBuildSrcVersion(project.file('version.properties'))
|
|
version = props.getProperty("elasticsearch")
|
|
|
|
def generateVersionProperties = tasks.register("generateVersionProperties", WriteProperties) {
|
|
outputFile = "${buildDir}/version.properties"
|
|
comment = 'Generated version properties'
|
|
properties(props)
|
|
}
|
|
|
|
processResources {
|
|
from(generateVersionProperties)
|
|
}
|
|
|
|
/*****************************************************************************
|
|
* Java version *
|
|
*****************************************************************************/
|
|
|
|
if (JavaVersion.current() < JavaVersion.VERSION_11) {
|
|
throw new GradleException('At least Java 11 is required to build elasticsearch gradle tools')
|
|
}
|
|
|
|
sourceSets {
|
|
integTest {
|
|
compileClasspath += sourceSets["main"].output + configurations["testRuntimeClasspath"]
|
|
runtimeClasspath += output + compileClasspath
|
|
}
|
|
}
|
|
|
|
tasks.withType(JavaCompile).configureEach {
|
|
options.encoding = 'UTF-8'
|
|
}
|
|
|
|
/*****************************************************************************
|
|
* Dependencies used by the entire build *
|
|
*****************************************************************************/
|
|
|
|
repositories {
|
|
jcenter()
|
|
}
|
|
|
|
dependencies {
|
|
|
|
api localGroovy()
|
|
|
|
api 'commons-codec:commons-codec:1.12'
|
|
api 'org.apache.commons:commons-compress:1.19'
|
|
|
|
api 'com.netflix.nebula:gradle-extra-configurations-plugin:3.0.3'
|
|
api 'com.netflix.nebula:nebula-publishing-plugin:4.4.4'
|
|
api 'com.netflix.nebula:gradle-info-plugin:7.1.3'
|
|
api 'org.apache.rat:apache-rat:0.11'
|
|
api "org.elasticsearch:jna:5.5.0"
|
|
api 'com.github.jengelman.gradle.plugins:shadow:6.0.0'
|
|
api 'de.thetaphi:forbiddenapis:3.0'
|
|
api 'com.avast.gradle:gradle-docker-compose-plugin:0.12.1'
|
|
api 'org.apache.maven:maven-model:3.6.2'
|
|
api 'com.networknt:json-schema-validator:1.0.36'
|
|
|
|
compileOnly "com.puppycrawl.tools:checkstyle:${props.getProperty('checkstyle')}"
|
|
testImplementation "com.puppycrawl.tools:checkstyle:${props.getProperty('checkstyle')}"
|
|
testFixturesApi "junit:junit:${props.getProperty('junit')}"
|
|
testFixturesApi "com.carrotsearch.randomizedtesting:randomizedtesting-runner:${props.getProperty('randomizedrunner')}"
|
|
testFixturesApi gradleApi()
|
|
testFixturesApi gradleTestKit()
|
|
testImplementation 'com.github.tomakehurst:wiremock-jre8-standalone:2.23.2'
|
|
testImplementation 'org.mockito:mockito-core:1.9.5'
|
|
integTestImplementation('org.spockframework:spock-core:1.3-groovy-2.5') {
|
|
exclude module: "groovy"
|
|
}
|
|
}
|
|
|
|
/*****************************************************************************
|
|
* Bootstrap repositories *
|
|
*****************************************************************************/
|
|
// this will only happen when buildSrc is built on its own during build init
|
|
if (project == rootProject) {
|
|
repositories {
|
|
if (System.getProperty("repos.mavenLocal") != null) {
|
|
mavenLocal()
|
|
}
|
|
}
|
|
dependencies {
|
|
// add this so the runtime classpath so Gradle will properly track it as a build runtime classpath input
|
|
runtimeOnly project('reaper')
|
|
}
|
|
// only run tests as build-tools
|
|
test.enabled = false
|
|
}
|
|
|
|
/*****************************************************************************
|
|
* Normal project checks *
|
|
*****************************************************************************/
|
|
|
|
// this happens when included as a normal project in the build, which we do
|
|
// to enforce precommit checks like forbidden apis, as well as setup publishing
|
|
if (project != rootProject) {
|
|
apply plugin: 'elasticsearch.build'
|
|
apply plugin: 'elasticsearch.publish'
|
|
|
|
allprojects {
|
|
targetCompatibility = 10
|
|
sourceCompatibility = 10
|
|
}
|
|
|
|
// groovydoc succeeds, but has some weird internal exception...
|
|
groovydoc.enabled = false
|
|
|
|
// build-tools is not ready for primetime with these...
|
|
tasks.named("dependencyLicenses").configure { it.enabled = false }
|
|
dependenciesInfo.enabled = false
|
|
disableTasks('forbiddenApisMain', 'forbiddenApisTest', 'forbiddenApisIntegTest', 'forbiddenApisTestFixtures')
|
|
jarHell.enabled = false
|
|
thirdPartyAudit.enabled = false
|
|
if (org.elasticsearch.gradle.info.BuildParams.inFipsJvm) {
|
|
// We don't support running gradle with a JVM that is in FIPS 140 mode, so we don't test it.
|
|
// WaitForHttpResourceTests tests would fail as they use JKS/PKCS12 keystores
|
|
test.enabled = false
|
|
testingConventions.enabled = false
|
|
}
|
|
|
|
configurations.register("distribution")
|
|
configurations.register("reaper")
|
|
|
|
dependencies {
|
|
reaper project('reaper')
|
|
distribution project(':distribution:archives:windows-zip')
|
|
distribution project(':distribution:archives:oss-windows-zip')
|
|
distribution project(':distribution:archives:darwin-tar')
|
|
distribution project(':distribution:archives:oss-darwin-tar')
|
|
distribution project(':distribution:archives:linux-aarch64-tar')
|
|
distribution project(':distribution:archives:linux-tar')
|
|
distribution project(':distribution:archives:oss-linux-tar')
|
|
distribution project(':distribution:archives:oss-linux-aarch64-tar')
|
|
|
|
integTestRuntimeOnly(project(":libs:elasticsearch-core"))
|
|
}
|
|
|
|
// for external projects we want to remove the marker file indicating we are running the Elasticsearch project
|
|
processResources {
|
|
exclude 'buildSrc.marker'
|
|
into('META-INF') {
|
|
from configurations.reaper
|
|
}
|
|
}
|
|
|
|
// Track reaper jar as a test input using runtime classpath normalization strategy
|
|
tasks.withType(Test).configureEach {
|
|
inputs.files(configurations.reaper).withNormalizer(ClasspathNormalizer)
|
|
}
|
|
|
|
normalization {
|
|
runtimeClasspath {
|
|
// We already include the reaper jar as part of our runtime classpath. Ignore the copy in META-INF.
|
|
ignore('META-INF/reaper.jar')
|
|
}
|
|
}
|
|
|
|
forbiddenPatterns {
|
|
exclude '**/*.wav'
|
|
exclude '**/*.p12'
|
|
exclude '**/*.jks'
|
|
exclude '**/*.crt'
|
|
// the file that actually defines nocommit
|
|
exclude '**/ForbiddenPatternsTask.java'
|
|
exclude '**/*.bcfks'
|
|
}
|
|
|
|
testingConventions {
|
|
naming.clear()
|
|
naming {
|
|
Tests {
|
|
baseClass 'org.elasticsearch.gradle.test.GradleUnitTestCase'
|
|
}
|
|
IT {
|
|
baseClass 'org.elasticsearch.gradle.test.GradleIntegrationTestCase'
|
|
}
|
|
}
|
|
}
|
|
|
|
tasks.register("integTest", Test) {
|
|
inputs.dir(file("src/testKit")).withPropertyName("testkit dir").withPathSensitivity(PathSensitivity.RELATIVE)
|
|
systemProperty 'test.version_under_test', version
|
|
onlyIf { org.elasticsearch.gradle.info.BuildParams.inFipsJvm == false }
|
|
maxParallelForks = System.getProperty('tests.jvms', org.elasticsearch.gradle.info.BuildParams.defaultParallel.toString()) as Integer
|
|
testClassesDirs = sourceSets.integTest.output.classesDirs
|
|
classpath = sourceSets.integTest.runtimeClasspath
|
|
}
|
|
check.dependsOn("integTest")
|
|
|
|
// for now we hardcode the tests for our build to use the gradle jvm.
|
|
tasks.withType(Test).configureEach {
|
|
it.executable = Jvm.current().getJavaExecutable()
|
|
}
|
|
|
|
/*
|
|
* We already configure publication and we don't need or want this one that
|
|
* comes from the java-gradle-plugin.
|
|
*/
|
|
afterEvaluate {
|
|
generatePomFileForPluginMavenPublication.enabled = false
|
|
}
|
|
|
|
publishing.publications.named("nebula").configure {
|
|
suppressPomMetadataWarningsFor("testFixturesApiElements")
|
|
suppressPomMetadataWarningsFor("testFixturesRuntimeElements")
|
|
}
|
|
}
|
|
|
|
// Define this here because we need it early.
|
|
class VersionPropertiesLoader {
|
|
static Properties loadBuildSrcVersion(File input) throws IOException {
|
|
Properties props = new Properties();
|
|
InputStream is = new FileInputStream(input)
|
|
try {
|
|
props.load(is)
|
|
} finally {
|
|
is.close()
|
|
}
|
|
loadBuildSrcVersion(props, System.getProperties())
|
|
return props
|
|
}
|
|
|
|
protected static void loadBuildSrcVersion(Properties loadedProps, Properties systemProperties) {
|
|
String elasticsearch = loadedProps.getProperty("elasticsearch")
|
|
if (elasticsearch == null) {
|
|
throw new IllegalStateException("Elasticsearch version is missing from properties.")
|
|
}
|
|
if (elasticsearch.matches("[0-9]+\\.[0-9]+\\.[0-9]+") == false) {
|
|
throw new IllegalStateException(
|
|
"Expected elasticsearch version to be numbers only of the form X.Y.Z but it was: " +
|
|
elasticsearch
|
|
)
|
|
}
|
|
String qualifier = systemProperties.getProperty("build.version_qualifier", "");
|
|
if (qualifier.isEmpty() == false) {
|
|
if (qualifier.matches("(alpha|beta|rc)\\d+") == false) {
|
|
throw new IllegalStateException("Invalid qualifier: " + qualifier)
|
|
}
|
|
elasticsearch += "-" + qualifier
|
|
}
|
|
final String buildSnapshotSystemProperty = systemProperties.getProperty("build.snapshot", "true");
|
|
switch (buildSnapshotSystemProperty) {
|
|
case "true":
|
|
elasticsearch += "-SNAPSHOT"
|
|
break;
|
|
case "false":
|
|
// do nothing
|
|
break;
|
|
default:
|
|
throw new IllegalArgumentException(
|
|
"build.snapshot was set to [" + buildSnapshotSystemProperty + "] but can only be unset or [true|false]");
|
|
}
|
|
loadedProps.put("elasticsearch", elasticsearch)
|
|
}
|
|
}
|