繁体   English   中英

如何模拟OracleConnection和OracleCommand?

[英]How can I mock an OracleConnection and OracleCommand?

对于我的测试,我需要模拟数据客户端,在我的例子中,他们是Oracle。

我创建了我的数据访问层以允许传入:

public static Int32? GetUserRoleId(string userName, OracleConnection cn, OracleCommand cmd)

我正在使用Moq,虽然我可以根据需要切换到另一个框架,当我去创建像这样的Mock对象时:

Mock<OracleConnection> mockOracleConnection = new Mock<OracleConnection>();
Mock<OracleCommand> mockOracleCommand = new Mock<OracleCommand>();

我收到此错误:

失败:System.ArgumentException:类型为mock必须是接口或抽象或非密封类。

结论:这比我想象的更简单! 只需像这样模拟DAL层函数:

mockDao.Setup(a => a.GetUserRoleId(userName, It.IsAny<OracleConnection>(), It.IsAny<OracleCommand>())).Returns(1);

您可以进行更改以使用IDbConnection和IDbCommand(使用接口并使用工厂在主代码中提供真实对象并在测试中提供模拟对象 - 通常使用依赖注入)

Moq只能模拟接口和虚拟方法。

你正试图嘲笑一个密封的课:你可以看看这里

BTW:正如@Aliostad 所说 ,这样的框架 - 我见过的大多数模拟框架 - 都只能模拟Interfaces / Abstract类。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM