mirror of https://github.com/apache/lucene.git
LUCENE-9179: don't invoke the same build recursively upon first run, just continue. Seems like gradle bug but let's not cry about it - it just happens once and CI defaults can be passed independently on command-line.
This commit is contained in:
parent
8e357b167b
commit
b420ef8f77
|
@ -4,48 +4,37 @@
|
||||||
|
|
||||||
def hasDefaults = rootProject.file("gradle.properties").exists()
|
def hasDefaults = rootProject.file("gradle.properties").exists()
|
||||||
|
|
||||||
// If we don't have the defaults yet, create them and re-run the build
|
// If we don't have the defaults yet, create them.
|
||||||
// recursively with the same parameters as originally passed.
|
|
||||||
//
|
|
||||||
// Sadly, the recursive build doesn't seem to pick up the parallelism
|
|
||||||
// tweaks from gradle.properties file.
|
|
||||||
|
|
||||||
if (!hasDefaults) {
|
if (!hasDefaults) {
|
||||||
configure(rootProject) {
|
configure(rootProject) {
|
||||||
task setupLocalDefaultsOnce(type: GradleBuild) {
|
task localSettings() {
|
||||||
// Approximate a common-sense default for running gradle/tests with parallel
|
|
||||||
// workers: half the count of available cpus but not more than 12.
|
|
||||||
def cpus = Runtime.runtime.availableProcessors()
|
|
||||||
def maxWorkers = (int) Math.max(1d, Math.min(cpus * 0.5d, 12))
|
|
||||||
def testsJvms = (int) Math.max(1d, Math.min(cpus * 0.5d, 12))
|
|
||||||
|
|
||||||
// Reuse the same set of parameters for the recursive invocation and apply
|
|
||||||
// some of these eagerly.
|
|
||||||
def startParams = gradle.startParameter.newInstance()
|
|
||||||
startParams.setParallelProjectExecutionEnabled(true)
|
|
||||||
startParams.setMaxWorkerCount(maxWorkers)
|
|
||||||
startParameter(startParams)
|
|
||||||
|
|
||||||
// Write the defaults for this machine.
|
|
||||||
rootProject.file("gradle.properties").write(
|
|
||||||
[
|
|
||||||
"# These settings have been generated automatically on the first run.",
|
|
||||||
"# See gradlew :helpLocalSettings for more information.",
|
|
||||||
"systemProp.file.encoding=UTF-8",
|
|
||||||
"org.gradle.daemon=true",
|
|
||||||
"org.gradle.jvmargs=-Xmx2g",
|
|
||||||
"org.gradle.parallel=true",
|
|
||||||
"org.gradle.priority=normal",
|
|
||||||
"org.gradle.warning.mode=none", // Silence gradle warnings. We'll deal with them when we upgrade the wrapper.
|
|
||||||
"",
|
|
||||||
"# Maximum number of parallel gradle workers.",
|
|
||||||
"org.gradle.workers.max=${maxWorkers}",
|
|
||||||
"",
|
|
||||||
"# Maximum number of test JVMs forked per test task.",
|
|
||||||
"tests.jvms=${testsJvms}"
|
|
||||||
].join("\n"), "UTF-8")
|
|
||||||
|
|
||||||
doFirst {
|
doFirst {
|
||||||
|
// Approximate a common-sense default for running gradle/tests with parallel
|
||||||
|
// workers: half the count of available cpus but not more than 12.
|
||||||
|
def cpus = Runtime.runtime.availableProcessors()
|
||||||
|
def maxWorkers = (int) Math.max(1d, Math.min(cpus * 0.5d, 12))
|
||||||
|
def testsJvms = (int) Math.max(1d, Math.min(cpus * 0.5d, 12))
|
||||||
|
|
||||||
|
// Write the defaults for this machine.
|
||||||
|
rootProject.file("gradle.properties").write(
|
||||||
|
[
|
||||||
|
"# These settings have been generated automatically on the first run.",
|
||||||
|
"# See gradlew :helpLocalSettings for more information.",
|
||||||
|
"systemProp.file.encoding=UTF-8",
|
||||||
|
"org.gradle.daemon=true",
|
||||||
|
"org.gradle.jvmargs=-Xmx2g",
|
||||||
|
"org.gradle.parallel=true",
|
||||||
|
"org.gradle.priority=normal",
|
||||||
|
"org.gradle.warning.mode=none", // Silence gradle warnings. We'll deal with them when we upgrade the wrapper.
|
||||||
|
"",
|
||||||
|
"# Maximum number of parallel gradle workers.",
|
||||||
|
"org.gradle.workers.max=${maxWorkers}",
|
||||||
|
"",
|
||||||
|
"# Maximum number of test JVMs forked per test task.",
|
||||||
|
"tests.jvms=${testsJvms}"
|
||||||
|
].join("\n"), "UTF-8")
|
||||||
|
|
||||||
logger.log(LogLevel.WARN, "\nIMPORTANT. This is the first time you ran the build. " +
|
logger.log(LogLevel.WARN, "\nIMPORTANT. This is the first time you ran the build. " +
|
||||||
"I wrote some sane defaults (for this machine) to 'gradle.properties', " +
|
"I wrote some sane defaults (for this machine) to 'gradle.properties', " +
|
||||||
"they will be picked up on consecutive gradle invocations (not this one).\n\n" +
|
"they will be picked up on consecutive gradle invocations (not this one).\n\n" +
|
||||||
|
@ -54,20 +43,11 @@ if (!hasDefaults) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disable any tasks in this build, they were forked recursively.
|
|
||||||
gradle.taskGraph.whenReady { graph ->
|
|
||||||
graph.allTasks.each { task ->
|
|
||||||
if (task != rootProject.setupLocalDefaultsOnce) {
|
|
||||||
task.enabled = false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Make all tasks depend on local setup to make sure it'll run.
|
// Make all tasks depend on local setup to make sure it'll run.
|
||||||
allprojects {
|
allprojects {
|
||||||
tasks.all { task ->
|
tasks.all { task ->
|
||||||
if (task != rootProject.setupLocalDefaultsOnce) {
|
if (task != rootProject.localSettings) {
|
||||||
task.dependsOn rootProject.setupLocalDefaultsOnce
|
task.dependsOn rootProject.localSettings
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue