0

在编写测试时,我有时只想将文本写入控制台以进行调试。

如何在 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
    }
}
4

1 回答 1

1

在这方面,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')

PS:看过你最后两个问题后,我真的建议先阅读 Groovy 教程,然后再阅读 Spock 手册,然后再提出更多问题。没有冒犯的意思,我只是想帮助你自助。

于 2020-07-17T02:21:18.353 回答