2

在我的控制器中,我有一个使用条件来命中数据库并获取结果的操作。

params.max = Math.min(params.max ? params.int('max') : 20, 100)    
def c = DomainObj.createCriteria()
    def result =[]
    result = c.list(params) {
        'eq'("employerid", id)
        }

我以这种方式在我的测试用例中模拟了这个调用:

def result=[DomainObj1]         
            def mycriteria =[
                list: {Object params=null,Closure cls -> result}                    
                ]

DomainObj.metaClass.static.createCriteria = {mycriteria}

到目前为止工作正常。

但在控制器中,有一行代码显示 result.totalCount,其中 result 是条件查询的输出,属于 PagedResultList 类型。但是在测试用例中,我将结果模拟为arrayList,而不是PagedResultList。因此,如果从测试用例运行,代码会在 result.totalCount 处中断。

关于如何模拟对 PagedResultList 而不是 arraylist 的标准响应的任何想法,以便它具有 totalCount

4

2 回答 2

0

看看它的界面。你可以像这样编写它

result = new PagedResultList(list: inctanceList, totalCount: inctanceList.size())
于 2012-07-31T06:28:06.173 回答
0

对于 Grails3,您可以使用 Groovy 的tap闭包:

PagedResultList<Foo> list = new PagedResultList<Foo>(null).tap {
    totalCount = 23
    resultList = [ foo1, foo2, foo3 ]
}
于 2020-04-01T18:44:50.117 回答