/* * 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:5.1.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) } }