如何在 spock 测试中将任意文本写入控制台?
How do I write arbitrary text to the console in a spock test?
在编写测试时,我有时只想将文本写入控制台以进行调试。
如何在 spock 测试中执行此操作?我尝试使用记录器,但它抛出错误:
import javaposse.jobdsl.dsl.DslScriptLoader
import javaposse.jobdsl.plugin.JenkinsJobManagement
import org.junit.ClassRule
import org.jvnet.hudson.test.JenkinsRule
import spock.lang.Shared
import spock.lang.Specification
import spock.lang.Unroll
import java.util.logging.Logger
class JobScriptsSpec extends Specification {
@Shared
@ClassRule
JenkinsRule jenkinsRule = new JenkinsRule()
Logger logger = Logger.getLogger("")
@Unroll
def 'test script #file.name'(File file) {
given:
def jobManagement = new JenkinsJobManagement(System.out, [:], new File('.'))
when:
new DslScriptLoader(jobManagement).runScript(file.text)
then:
noExceptionThrown()
where:
// This throws an error
logger.info ("zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz")
file << jobFiles
}
static List<File> getJobFiles() {
List<File> files = []
new File('jobs').eachFileRecurse {
if (it.name.endsWith('.groovy')) {
files << it
}
}
files
}
}
Groovy 在这方面与 Java 没有什么不同。大多数情况下 Groovy 是 Java 语法的超集。所以你可以写 System.out.println("hey")
或 groovy 方式 println "hey"
.
使用记录器也可以。也许你不应该在 where:
块中记录任何内容,因为 Spock 需要你的数据表或数据提供者,而不是程序代码。将代码放入它所属的块中,即除了 where:
之外的任何其他地方。您的 logger.info "hey"
甚至不应该编译,您看到的错误应该是:
Error:(18, 5) Groovyc:
where-blocks may only contain parameterizations
(e.g. 'salary << [1000, 5000, 9000]; salaryk = salary / 1000')
P.S.: 看到你的最后两个问题后,我真的建议在问更多问题之前先阅读 Groovy 教程,然后再阅读 Spock 手册。没有冒犯的意思,我只是想帮助你自助。