org.gradle.testing.testng.TestNGConsoleLoggingIntegrationTest.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 2012 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.testng
import org.gradle.integtests.fixtures.AbstractIntegrationSpec
// can make assumptions about order in which test methods of TestNGTest get executed
// because the methods are chained with 'methodDependsOn'
class TestNGConsoleLoggingIntegrationTest extends AbstractIntegrationSpec {
def setup() {
executer.noExtraLogging()
buildFile << """
apply plugin: "groovy"
repositories {
mavenCentral()
}
dependencies {
compile "org.codehaus.groovy:groovy:2.4.7"
testCompile "org.testng:testng:6.3.1"
}
test {
useTestNG()
testLogging {
quiet {
events "skipped", "failed"
minGranularity 2
maxGranularity -1
displayGranularity 3
exceptionFormat "full"
stackTraceFilters "truncate", "groovy"
}
}
}
"""
file("src/test/groovy/org/gradle/TestNGTest.groovy") << """
package org.gradle
import org.testng.annotations.Test
class TestNGTest {
@Test
void goodTest() {}
@Test(dependsOnMethods = ["goodTest"])
void badTest() {
beBad()
}
@Test(dependsOnMethods = ["badTest"])
void ignoredTest() {}
@Test(dependsOnMethods = ["goodTest"])
void printTest() {
println "line 1\\nline 2"
println "line 3"
}
private beBad() {
throw new RuntimeException("bad")
}
}
"""
}
def "defaultLifecycleLogging"() {
when:
fails "test"
then:
outputContains("""
Gradle test > org.gradle.TestNGTest.badTest FAILED
java.lang.RuntimeException at TestNGTest.groovy:25
""")
}
def customQuietLogging() {
when:
executer.withStackTraceChecksDisabled()
args "-q"
fails "test"
then:
outputContains("""
Gradle test > org.gradle.TestNGTest.badTest FAILED
java.lang.RuntimeException: bad
at org.gradle.TestNGTest.beBad(TestNGTest.groovy:25)
at org.gradle.TestNGTest.badTest(TestNGTest.groovy:12)
Gradle test > org.gradle.TestNGTest.ignoredTest SKIPPED
Gradle test FAILED
Gradle suite FAILED
""")
}
def "standardOutputLogging"() {
given:
buildFile.text = """
apply plugin: "groovy"
repositories {
mavenCentral()
}
dependencies {
compile "org.codehaus.groovy:groovy:2.4.7"
testCompile "org.testng:testng:6.3.1"
}
test {
useTestNG()
testLogging {
quiet {
events "standardOut", "standardError"
}
}
}
"""
and:
file("src/test/groovy/org/gradle/TestNGStandardOutputTest.groovy") << """
package org.gradle
import org.testng.annotations.Test
class TestNGStandardOutputTest {
@Test
void printTest() {
println "line 1\\nline 2"
println "line 3"
}
}
"""
when:
args "-q"
fails "test"
then:
outputContains("""
Gradle test > org.gradle.TestNGStandardOutputTest.printTest STANDARD_OUT
line 1
line 2
line 3
""")
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy