gpt4 book ai didi

grails - 模拟groovy.sql.Sql.call(_,_,_)方法

转载 作者:行者123 更新时间:2023-12-02 15:21:30 27 4
gpt4 key购买 nike

我正在尝试模拟groovy.sql.Sql调用(查询,params [],闭包)类。
下面是我正在尝试在DatabaseService类文件中的方法。

public void getUsers(List<User> developerList, Sql sql) {
sql.call("{? = call GETUSERS()}", [Sql.resultSet(OracleTypes.CURSOR)]) { result ->
while (result.next()) {
User user = new User()
user .email = result.EMAIL
user .lastName = result.LASTNAME
}
}
}

我的模拟确实完成了任务,但是,我不希望模拟的闭包执行。我想模拟.call(,, _)方法仅跳过数据库逻辑,然后将列表返回给getUsers()方法中的闭包。我希望闭包在getUsers()方法中执行,而不是在模拟方法中执行。

以下是我在SPOCK中编写的样机。
void "test getUsers(list,sql) some results"() {
DataSource mockedSource = Mock(DataSource)
Sql mockedSql = Mock(Sql)
DatabaseService databaseService = new DatabaseService()
databaseService.dataSource = mockedSource
List<User> userList= new ArrayList<>();

when:
databaseService.getUsers(userList, mockedSql)

then:
1 * mockedSql.call(_, _, _) >> { return [[EMAIL: "A", LASTNAME: "B"]] }
userList.size() == 1
}

如所想象的,此模型将覆盖原始方法的关闭,并且我的列表永远不会填充。我当然不想重写我的类以使用Java,也不想更改执行的存储过程。

最佳答案

try :
int resultSetIdx = 0
def resutSet = Mock(ResultSet)
...
then:
1 * mockedSql.call(_, _, _) >> { args -> args[2].call(resultSet) }
2 * mockedResultset.next() >> { ++resultSetIdx > 1 ? false: true}
1 * mockedResultset.getString("EMAIL") >> "A"

在getUsers method()中更改
user.lastName = result.LASTNAME
user.email = result.EMAIL


user.lastName = result.getString("LASTNAME")
user.email = result.getString("EMAIL")

但是,您不应模拟 Sql,而应重写服务/ dao层以使其更具可测试性。使用内存数据库测试dao,并使用模拟的dao测试服务层。

关于grails - 模拟groovy.sql.Sql.call(_,_,_)方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35299942/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com