| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF 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.apache.tools.ant.taskdefs.condition.Os |
| import org.apache.tools.ant.types.Commandline |
| import org.gradle.api.tasks.testing.logging.* |
| import org.apache.lucene.gradle.ErrorReportingTestListener |
| |
| def verboseModeHookInstalled = false |
| |
| allprojects { |
| plugins.withType(JavaPlugin) { |
| def verboseMode = Boolean.parseBoolean(propertyOrDefault("tests.verbose", "false")) |
| |
| project.ext { |
| testsCwd = file("${buildDir}/tmp/tests-cwd") |
| testsTmpDir = file(propertyOrDefault("tests.workDir", "${buildDir}/tmp/tests-tmp")) |
| commonDir = project(":lucene").projectDir |
| commonSolrDir = project(":solr").projectDir |
| } |
| |
| // If we're running in verbose mode and: |
| // 1) worker count > 1 |
| // 2) number of 'test' tasks in the build is > 1 |
| // then the output would very likely be mangled on the |
| // console. Fail and let the user know what to do. |
| if (verboseMode && !verboseModeHookInstalled) { |
| verboseModeHookInstalled = true |
| if (gradle.startParameter.maxWorkerCount > 1) { |
| gradle.taskGraph.whenReady { graph -> |
| def testTasks = graph.allTasks.findAll { task -> task instanceof Test } |
| if (testTasks.size() > 1) { |
| throw new GradleException("Run your tests in verbose mode only with --max-workers=1 option passed to gradle.") |
| } |
| } |
| } |
| } |
| |
| test { |
| ext { |
| testOutputsDir = file("${reports.junitXml.destination}/outputs") |
| } |
| |
| if (verboseMode) { |
| maxParallelForks = 1 |
| } else { |
| maxParallelForks = propertyOrDefault("tests.jvms", (int) Math.max(1, Math.min(Runtime.runtime.availableProcessors() / 2.0, 4.0))) as Integer |
| } |
| |
| workingDir testsCwd |
| useJUnit() |
| |
| minHeapSize = propertyOrDefault("tests.minheapsize", "256m") |
| maxHeapSize = propertyOrDefault("tests.heapsize", "512m") |
| |
| jvmArgs Commandline.translateCommandline(propertyOrDefault("tests.jvmargs", "-XX:TieredStopAtLevel=1")) |
| |
| systemProperty 'java.util.logging.config.file', file("${commonDir}/tools/junit4/logging.properties") |
| systemProperty 'java.awt.headless', 'true' |
| systemProperty 'jdk.map.althashing.threshold', '0' |
| |
| if (!Os.isFamily(Os.FAMILY_WINDOWS)) { |
| systemProperty 'java.security.egd', 'file:/dev/./urandom' |
| } |
| |
| // jetty-related. |
| systemProperty 'jetty.testMode', '1' |
| systemProperty 'jetty.insecurerandom', '1' |
| |
| // Turn jenkins blood red for hashmap bugs, even on jdk7 |
| systemProperty 'jdk.map.althashing.threshold', '0' |
| |
| // Pass these to RandomizedRunner so that it doesn't attempt to set them. |
| systemProperty 'junit4.childvm.count', '1' |
| systemProperty 'junit4.childvm.id', '0' |
| |
| // Set up cwd and temp locations. |
| systemProperty("java.io.tmpdir", testsTmpDir) |
| systemProperty("tempDir", testsTmpDir) |
| doFirst { |
| testsCwd.mkdirs() |
| testsTmpDir.mkdirs() |
| } |
| |
| // Disable HTML report generation. The reports are big and slow to generate. |
| reports.html.enabled = false |
| |
| // Set up logging. |
| testLogging { |
| events TestLogEvent.FAILED |
| exceptionFormat TestExceptionFormat.FULL |
| showExceptions true |
| showCauses true |
| showStackTraces true |
| stackTraceFilters.clear() |
| showStandardStreams false |
| } |
| |
| // Set up custom test output handler. |
| doFirst { |
| project.delete testOutputsDir |
| } |
| |
| def spillDir = getTemporaryDir().toPath() |
| def listener = new ErrorReportingTestListener(test.testLogging, spillDir, testOutputsDir.toPath(), verboseMode) |
| addTestOutputListener(listener) |
| addTestListener(listener) |
| |
| doFirst { |
| // Print some diagnostics about locations used. |
| logger.info("Test folders for {}: cwd={}, tmp={}", project.path, testsCwd, testsTmpDir) |
| } |
| } |
| } |
| } |