5

我在 Grails 项目中执行了一组规范测试。

当我在本地时,我需要执行一组 Specs,而当我运行 pre-prod 环境时,我需要执行另一组 Specs。我当前的配置正在同时为两个环境执行我的所有规范,这是我想要避免的。

我在 GebConfig 中配置了多个环境:

environments {
    local {
        baseUrl = "http://localhost:8090/myApp/login/auth"
    }

    pre-prod {
        baseUrl = "https://preprod/myApp/login/auth"
    }

}
4

1 回答 1

4

您可以使用 spock 配置文件。

为两种类型的测试创建注释 -@Local@PreProd,例如在 Groovy 中:

import java.lang.annotation

@Retention(RetentionPolicy.RUNTIME)
@Target([ElementType.TYPE, ElementType.METHOD])
@Inherited
public @interface Local {}

下一步是相应地注释您的规范,例如:

@Local
class SpecificationThatRunsLocally extends GebSpec { ... }

SpockConfig.groovy然后在您的文件旁边创建一个文件GebConfig.groovy,其中包含以下内容:

def gebEnv = System.getProperty("geb.env")
if (gebEnv) {
    switch(gebEnv) {
        case 'local':
            runner { include Local }
            break
        case 'pre-prod':
            runner { include PreProd }
            break 
    }
}

编辑:看起来 Grails 正在使用它自己的测试运行程序,这意味着从 Grails 运行规范时不考虑 SpockConfig.groovy。如果你需要它在 Grails 下工作,那么你应该使用 @IgnoreIf/@Require 内置的 Spock 扩展注解。

首先创建一个闭包类,其中包含何时启用给定规范的逻辑。您可以将逻辑直接作为扩展注释的闭包参数放置,但如果您想注释很多规范,则将那段代码复制到整个地方会很烦人。

class Local extends Closure<Boolean> {
    public Local() { super(null) }
    Boolean doCall() {
        System.properties['geb.env'] == 'local'
    }
} 

class PreProd extends Closure<Boolean> {
    public PreProd() { super(null) }
    Boolean doCall() {
        System.properties['geb.env'] == 'pre-prod'
    }
}

然后注释您的规格:

@Requires(Local)
class SpecificationThatRunsLocally extends GebSpec { ... }

@Requires(PreProd)
class SpecificationThatRunsInPreProd extends GebSpec { ... }
于 2013-09-06T09:10:18.283 回答