0

使用 grails 2.5.1,我只创建了一个具有通过构造函数初始化的简单属性的服务(@PostConstruct 也是)

任何通过服务方法读取此属性的单元测试都会获得 NullPointerException

以下是如何重现:

grails> create-app acme
grails> create-service DataService

acme/DataService.groovy

@Transactional
class DataService {

    def data = null;

    @PostConstruct
    def setup() {
        if (data == null) {
            println("Initializing the service ...")
            data = "<DATA>"
        }
    }

    def serviceMethod() {
        setup()
    }

    def getDataLength() {
        println("Getting data length ...")
        return data.length(); // Line 26
    }
}

acme/DataServiceSpec.groovy

@TestFor(DataService)
class DataServiceSpec extends Specification {

    def setup() {
    }

    def cleanup() {
    }

    void "test data"() {
        given:
            int datalen = service.getDataLength()
        expect:
            datalen > 0
    }
}

运行测试....

grails> test-app -unit -echoOut

输出 ...

|Running 2 unit tests...
|Running 2 unit tests... 1 of 2
--Output from test data--
Initializing the service ...
Getting data length ...
Failure:  |
test data(acme.DataServiceSpec)
 |
java.lang.NullPointerException: Cannot invoke method length() on null object
        at acme.DataService.getDataLength(DataService.groovy:26)
        at acme.DataServiceSpec.test data(DataServiceSpec.groovy:20)
|Completed 1 unit test, 1 failed in 0m 2s
.Tests FAILED

日志显示属性初始化步骤和属性的 NullPointerException。

问题是:

  • 为什么“数据”属性变为 null ?
  • 有一个服务生命周期将属性设置为 null 吗?
  • 正在运行的测试是否使用与初始化实例不同的 DataService 实例?
4

1 回答 1

2

您是否在 @PostConstruct 上看到 Grails 单元测试失败

在单元测试中并使用 @TestFor 注释 @PostConstruct 不被调用。您可以为测试或调用设置方法创建构造。

于 2015-09-28T23:32:25.567 回答