我正在尝试通过以下方式在Groovy中模拟Sql实例,我正在使用spock框架进行测试。但是测试失败,请参见以下内容:
class SQLStatsStorageManagerTest extends Specification {
def mockSql
def setup() {
mockSql = GroovyMock(Sql, global: true)
}
void "SQLStatsStorageManager instantiation succeed"() {
def c
when: "SQLStatsStorageManager is instantiated"
c = new SQLStatsStorageManager("test", [hostname: "localhost", port: 666, database: "db", login: "root", password: "pass"])
then: "there is no error and name is set"
1 * mockSql.newInstance('jdbc:mysql://localhost:666/db', 'root', 'pass', 'com.mysql.jdbc.Driver')
assert c.getName() == "test"
}
}
测试失败,并出现以下错误:
Too few invocations for:
1 * mockSql.newInstance('jdbc:mysql://localhost:666/db', 'root', 'pass', 'com.mysql.jdbc.Driver') (0 invocations)
Unmatched invocations (ordered by similarity):
1 * mockSql.newInstance(jdbc:mysql://localhost:666/db, 'root', 'pass', 'com.mysql.jdbc.Driver')
任何想法 ?
谢谢。
最佳答案
请注意,唯一不匹配的参数是db link。
您尝试将其验证为String
的实例:
'jdbc:mysql://localhost:666/db'
但在无与伦比的调用中,它是:
jdbc:mysql://localhost:666/db
所以这是问题,实际上是什么?验证类型,即可解决问题。