在我的控制器中,我有一个使用条件来命中数据库并获取结果的操作。
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