我在单元测试上已经遇到了一些困难,我正在尝试使用我目前正在开发的一个小项目来学习它,我遇到了这个问题,这两个问题我希望你能帮助我
1-我的项目是一个MVC项目。我的单元测试应该从哪个级别开始?他们应该只关注业务层吗?他们还应该测试我的控制器上的操作吗?
2-我有一种方法可以验证用户名格式,然后访问数据库以检查它是否可供使用。返回一个布尔值,无论该用户名是否可用。人们会为这种方法创建一个单元测试吗?我对测试格式验证感兴趣,但是如何在不查询数据库的情况下检查它们?另外,如果格式正确,但用户名已在使用中,我将得到一个错误值,但验证有效。我可以解耦这个方法,但是只有在格式正确的情况下才应该进行数据库验证,因此它们应该以某种方式绑定在一起。具有单元测试知识的人将如何解决这个问题。或者有人会如何重构这个方法来测试它?我可以为数据库访问创建一个存根,但是如何在用户测试时将其附加到我的项目,但在本地运行时将其分离?
谢谢!
在您的具体情况下,您可以做的一件简单的事情是将验证方法分解为 3 种不同的方法:一种检查格式,一种检查数据库可用性,一种将它们结合在一起。这将允许您单独测试每个子功能。
在更复杂的场景中,其他技术可能有用。从本质上讲,这就是依赖注入和控制反转派上用场的地方(不幸的是,这些短语对不同的人来说意味着不同的东西,但了解基本思想通常是一个好的开始)。
您的目标应该是将“检查此用户名是否可用”的概念与检查数据库的实现分离。
所以,而不是这个:
public class Validation
{
public bool CheckUsername(string username)
{
bool isFormatValid = IsFormatValid(username);
return isFormatValid && DB.CheckUsernameAvailability(username);
}
}
Run Code Online (Sandbox Code Playgroud)
你可以这样做:
public class Validation
{
public bool CheckUsername(string username,
IUsernameAvailabilityChecker checker)
{
bool isFormatValid = IsFormatValid(username);
return isFormatValid && checker.CheckUsernameAvailability(username);
}
}
Run Code Online (Sandbox Code Playgroud)
然后,从您的单元测试代码中,您可以创建一个自定义IUsernameAvailabilityChecker
,它可以执行您想要的任何测试目的。另一方面,实际的生产代码可以使用不同的实现IUsernameAvailabilityChecker
来实际查询数据库。
请记住,有很多很多技术可以解决此类测试问题,而且我给出的示例既简单又做作。