org.gradle.testkit.runner.GradleRunnerRetryRuleTest.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2017 the original author or authors.
*
* Licensed 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.
*/
package org.gradle.testkit.runner
import org.gradle.integtests.fixtures.RetryRuleUtil
import org.gradle.tooling.GradleConnectionException
import org.gradle.util.GradleVersion
import org.gradle.util.Requires
class GradleRunnerRetryRuleTest extends BaseGradleRunnerIntegrationTest {
def setup() {
//these meta tests mess with the daemon log: do not interfere with other tests when running in parallel
requireIsolatedTestKitDir = true
}
def iteration = 0
def "retries on clock shift issue for <2.10"() {
given:
iteration++
def isVersionWithIssue = gradleVersion < GradleVersion.version('2.10')
when:
throwWhen(new GradleConnectionException("Test Exception",
new IllegalArgumentException("Unable to calculate percentage: 19 of -233. All inputs must be >= 0")), isVersionWithIssue && iteration == 1)
then:
true
}
@Requires(adhoc = {RetryRuleUtil.runsOnWindowsAndJava7or8()})
def "retries if expected socket exception occurs"() {
given:
iteration++
when:
logToFakeDaemonLog('java.net.SocketException: Socket operation on nonsocket: no further information')
throwWhen(new IOException("Could not dispatch a message to the daemon.",
new IOException("Some exception in the chain",
new IOException("An existing connection was forcibly closed by the remote host"))), iteration == 1)
then:
true
}
@Requires(adhoc = {!RetryRuleUtil.runsOnWindowsAndJava7or8()})
def "does not retry on non-windows and non-java environments"() {
given:
iteration++
when:
logToFakeDaemonLog('java.net.SocketException: Socket operation on nonsocket: no further information')
throwWhen(new IOException("Could not dispatch a message to the daemon.", new IOException("An existing connection was forcibly closed by the remote host")), iteration == 1)
then:
def ioe = thrown(IOException)
ioe.cause?.message == "An existing connection was forcibly closed by the remote host"
}
@Requires(adhoc = {RetryRuleUtil.runsOnWindowsAndJava7or8()})
def "should fail for unexpected cause on client side"() {
given:
iteration++
when:
logToFakeDaemonLog('java.net.SocketException: Socket operation on nonsocket: no further information')
throwWhen(new IOException("Could not dispatch a message to the daemon.", new IOException("A different cause")), iteration == 1)
then:
def ioe = thrown(IOException)
ioe.cause?.message == "A different cause"
}
@Requires(adhoc = {RetryRuleUtil.runsOnWindowsAndJava7or8()})
def "should fail for unexpected cause on daemon side"() {
given:
iteration++
when:
logToFakeDaemonLog("Caused by: java.net.SocketException: Something else")
throwWhen(new IOException("Could not dispatch a message to the daemon.", new IOException("An existing connection was forcibly closed by the remote host")), iteration == 1)
then:
def ioe = thrown(IOException)
ioe.message == "Could not dispatch a message to the daemon."
}
private static void throwWhen(Throwable throwable, boolean condition) {
if (condition) {
throw throwable
}
}
private void logToFakeDaemonLog(String exceptionInDaemon) {
def logDir = new File(daemonsFixture.daemonBaseDir, daemonsFixture.getVersion())
logDir.mkdirs()
def log = new File(logDir, "daemon-fake.log")
log << "DefaultDaemonContext[uid=0000,javaHome=javaHome,daemonRegistryDir=daemonRegistryDir,pid=-9999,idleTimeout=120000,daemonOpts=daemonOpts]\n"
log << exceptionInDaemon
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy