org.gradle.testing.junit.JUnitConsoleLoggingIntegrationTest.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 2018 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.testing.junit
import org.gradle.integtests.fixtures.DefaultTestExecutionResult
import org.gradle.integtests.fixtures.TargetCoverage
import org.gradle.integtests.fixtures.TestResources
import org.gradle.testing.fixture.JUnitMultiVersionIntegrationSpec
import org.junit.Rule
import static org.gradle.testing.fixture.JUnitCoverage.JUNIT_4_LATEST
import static org.gradle.testing.fixture.JUnitCoverage.JUNIT_VINTAGE_JUPITER
import static org.hamcrest.Matchers.equalTo
// cannot make assumptions about order in which test methods of JUnit4Test get executed
@TargetCoverage({ JUNIT_4_LATEST + JUNIT_VINTAGE_JUPITER })
class JUnitConsoleLoggingIntegrationTest extends JUnitMultiVersionIntegrationSpec {
@Rule TestResources resources = new TestResources(temporaryFolder)
def setup() {
executer.noExtraLogging()
}
def "defaultLifecycleLogging"() {
when:
fails("test")
then:
outputContains("""
org.gradle.JUnit4Test > badTest FAILED
java.lang.RuntimeException at JUnit4Test.groovy:44
""")
}
def "customQuietLogging"() {
when:
executer.withStackTraceChecksDisabled()
args("-q")
fails("test")
then:
outputContains("""
badTest FAILED
java.lang.RuntimeException: bad
at org.gradle.JUnit4Test.beBad(JUnit4Test.groovy:44)
at org.gradle.JUnit4Test.badTest(JUnit4Test.groovy:28)
""")
outputContains("ignoredTest SKIPPED")
outputContains("org.gradle.JUnit4Test FAILED")
}
def "standardOutputLogging"() {
when:
args("-q")
fails("test")
then:
outputContains("""
org.gradle.JUnit4StandardOutputTest > printTest STANDARD_OUT
line 1
line 2
line 3
""")
}
def "test logging is included in XML results"() {
file("build.gradle") << """
apply plugin: 'java'
${mavenCentralRepository()}
dependencies { testCompile 'junit:junit:4.12' }
"""
file("src/test/java/EncodingTest.java") << """
import org.junit.*;
public class EncodingTest {
@Test public void encodesCdata() {
System.out.println("< html allowed, cdata closing token ]]> encoded!");
System.out.print("no EOL, ");
System.out.println("non-asci char: ż");
System.out.println("xml entity: &");
System.err.println("< html allowed, cdata closing token ]]> encoded!");
}
@Test public void encodesAttributeValues() {
throw new RuntimeException("html: <> cdata: ]]>");
}
}
"""
when:
fails("test")
then:
new DefaultTestExecutionResult(testDirectory)
.testClass("EncodingTest")
.assertTestPassed("encodesCdata")
.assertTestFailed("encodesAttributeValues", equalTo('java.lang.RuntimeException: html: <> cdata: ]]>'))
.assertStdout(equalTo("""< html allowed, cdata closing token ]]> encoded!
no EOL, non-asci char: ż
xml entity: &
"""))
.assertStderr(equalTo("< html allowed, cdata closing token ]]> encoded!\n"))
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy