mirror of
https://github.com/elastic/elasticsearch.git
synced 2025-04-23 14:47:31 -04:00
* [Gradle] Remove static use of BuildParams (#115122)
Static fields dont do well in Gradle with configuration cache enabled.
- Use buildParams extension in build scripts
- Keep BuildParams.ci for now for easy serverless migration
- Tweak testing doc
(cherry picked from commit 13c8aaeffa
)
# Conflicts:
# TESTING.asciidoc
# build-tools-internal/src/main/java/org/elasticsearch/gradle/internal/InternalDistributionBwcSetupPlugin.java
# build-tools-internal/src/main/java/org/elasticsearch/gradle/internal/test/rest/RestTestBasePlugin.java
# build-tools-internal/src/main/java/org/elasticsearch/gradle/internal/test/rest/compat/compat/AbstractYamlRestCompatTestPlugin.java
# build.gradle
# modules/ingest-geoip/qa/full-cluster-restart/build.gradle
# qa/mixed-cluster/build.gradle
# x-pack/plugin/ent-search/qa/full-cluster-restart/build.gradle
# x-pack/plugin/eql/qa/rest/build.gradle
# x-pack/plugin/fleet/qa/rest/build.gradle
# x-pack/plugin/kql/build.gradle
# x-pack/plugin/mapper-unsigned-long/build.gradle
# x-pack/plugin/ml/qa/multi-cluster-tests-with-security/build.gradle
# x-pack/plugin/security/qa/multi-cluster/build.gradle
# x-pack/plugin/sql/qa/jdbc/build.gradle
# x-pack/plugin/transform/qa/multi-cluster-tests-with-security/build.gradle
* Fix merge
* [Build] Fix fips testing after buildparams rework (#116934)
* More Cleanup
* [Build] Fix checkstyle exclusions on windows (#115185)
* More merge fixes
* Delete x-pack/plugin/kql/build.gradle
93 lines
3.7 KiB
Groovy
93 lines
3.7 KiB
Groovy
import org.elasticsearch.gradle.internal.test.TestUtil
|
|
|
|
/*
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
* or more contributor license agreements. Licensed under the "Elastic License
|
|
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side
|
|
* Public License v 1"; you may not use this file except in compliance with, at
|
|
* your election, the "Elastic License 2.0", the "GNU Affero General Public
|
|
* License v3.0 only", or the "Server Side Public License, v 1".
|
|
*/
|
|
|
|
apply plugin: org.elasticsearch.gradle.internal.ElasticsearchJavaBasePlugin
|
|
apply plugin: 'java-library'
|
|
apply plugin: 'application'
|
|
|
|
var os = org.gradle.internal.os.OperatingSystem.current()
|
|
|
|
application {
|
|
mainClass = 'org.openjdk.jmh.Main'
|
|
}
|
|
|
|
tasks.named("assemble").configure { enabled = false }
|
|
base {
|
|
archivesName = 'elasticsearch-benchmarks'
|
|
}
|
|
|
|
tasks.named("test").configure { enabled = false }
|
|
tasks.named("javadoc").configure { enabled = false }
|
|
|
|
configurations {
|
|
expression
|
|
painless
|
|
nativeLib
|
|
}
|
|
|
|
dependencies {
|
|
api(project(":server")) {
|
|
// JMH ships with the conflicting version 4.6. This prevents us from using jopt-simple in benchmarks (which should be ok) but allows
|
|
// us to invoke the JMH uberjar as usual.
|
|
exclude group: 'net.sf.jopt-simple', module: 'jopt-simple'
|
|
}
|
|
api(project(':libs:elasticsearch-h3'))
|
|
api(project(':modules:aggregations'))
|
|
api(project(':x-pack:plugin:esql-core'))
|
|
api(project(':x-pack:plugin:esql'))
|
|
api(project(':x-pack:plugin:esql:compute'))
|
|
implementation project(path: ':libs:elasticsearch-simdvec')
|
|
expression(project(path: ':modules:lang-expression', configuration: 'zip'))
|
|
painless(project(path: ':modules:lang-painless', configuration: 'zip'))
|
|
nativeLib(project(':libs:elasticsearch-native'))
|
|
api "org.openjdk.jmh:jmh-core:$versions.jmh"
|
|
annotationProcessor "org.openjdk.jmh:jmh-generator-annprocess:$versions.jmh"
|
|
// Dependencies of JMH
|
|
runtimeOnly 'net.sf.jopt-simple:jopt-simple:5.0.4'
|
|
runtimeOnly 'org.apache.commons:commons-math3:3.6.1'
|
|
}
|
|
|
|
// enable the JMH's BenchmarkProcessor to generate the final benchmark classes
|
|
// needs to be added separately otherwise Gradle will quote it and javac will fail
|
|
tasks.named("compileJava").configure {
|
|
options.compilerArgs.addAll(["-processor", "org.openjdk.jmh.generators.BenchmarkProcessor"])
|
|
// org.elasticsearch.plugins.internal is used in signatures classes used in benchmarks but we don't want to expose it publicly
|
|
// adding an export to allow compilation with gradle. This does not solve a problem in intellij as it does not use compileJava task
|
|
options.compilerArgs.addAll(["--add-exports", "org.elasticsearch.server/org.elasticsearch.plugins.internal=ALL-UNNAMED"])
|
|
}
|
|
|
|
tasks.register('copyExpression', Copy) {
|
|
dependsOn configurations.expression
|
|
from { configurations.expression.collect { zipTree(it) } }
|
|
into "${buildDir}/plugins/expression"
|
|
}
|
|
|
|
tasks.register("copyPainless", Copy) {
|
|
dependsOn configurations.painless
|
|
from { configurations.painless.collect { zipTree(it) } }
|
|
into "${buildDir}/plugins/painless"
|
|
}
|
|
|
|
tasks.named("run").configure {
|
|
executable = "${buildParams.runtimeJavaHome.get()}/bin/java"
|
|
args << "-Dplugins.dir=${buildDir}/plugins" << "-Dtests.index=${buildDir}/index"
|
|
dependsOn "copyExpression", "copyPainless", configurations.nativeLib
|
|
systemProperty 'es.nativelibs.path', TestUtil.getTestLibraryPath(file("../libs/native/libraries/build/platform/").toString())
|
|
}
|
|
|
|
spotless {
|
|
java {
|
|
// IDEs can sometimes run annotation processors that leave files in
|
|
// here, causing Spotless to complain. Even though this path ought not
|
|
// to exist, exclude it anyway in order to avoid spurious failures.
|
|
targetExclude 'src/main/generated/**/*.java'
|
|
}
|
|
}
|