gpt4 book ai didi

unit-testing - 如何对具有数据库访问权限的方法进行单元测试?

转载 作者:行者123 更新时间:2023-12-03 00:37:47 26 4
gpt4 key购买 nike

我在单元测试上已经遇到了一些困难,我正在尝试在使用我目前正在开发的一个小项目时学习它,我遇到了这个问题,这两个问题我希望你能帮助我

1- 我的项目是一个 MVC 项目。我的单元测试应该从哪个级别开始?他们应该只关注业务层吗?他们还应该测试我的 Controller 上的操作吗?

2-我有一种方法可以验证用户名格式,然后访问数据库以检查它是否可供使用。返回一个 bool 值,无论该用户名是否可用。人们会为这种方法创建一个单元测试吗?我对测试格式验证感兴趣,但是如何在不查询数据库的情况下检查它们?另外,如果格式正确,但用户名已在使用中,我将得到一个错误值,但验证有效。我可以解耦这个方法,但是只有在格式正确的情况下才应该进行数据库验证,因此它们应该以某种方式绑定(bind)在一起。具有单元测试知识的人将如何解决这个问题。或者有人会如何重构这个方法来测试它?我可以为数据库访问创建一个 stub ,但是如何在用户测试时将其附加到我的项目,但在本地运行时将其分离?

谢谢!

最佳答案

在您的具体情况下,您可以做的一件简单的事情是将验证方法分解为 3 种不同的方法:一种检查格式,一种检查数据库可用性,一种将它们结合在一起。这将允许您单独测试每个子功能。

在更复杂的场景中,其他技术可能有用。本质上,这就是dependency injection的地方。和 inversion of control派上用场(不幸的是,这些短语对不同的人来说意味着不同的东西,但了解基本想法通常是一个好的开始)。

您的目标应该是将“检查此用户名是否可用”的概念与检查数据库的实现分离。

所以,而不是这个:

public class Validation
{
public bool CheckUsername(string username)
{
bool isFormatValid = IsFormatValid(username);
return isFormatValid && DB.CheckUsernameAvailability(username);
}
}

你可以这样做:

public class Validation
{
public bool CheckUsername(string username,
IUsernameAvailabilityChecker checker)
{
bool isFormatValid = IsFormatValid(username);
return isFormatValid && checker.CheckUsernameAvailability(username);
}
}

然后,从您的单元测试代码中,您可以创建一个自定义的 IUsernameAvailabilityChecker ,它可以执行您想要的任何测试目的。另一方面,实际的生产代码可以使用 IUsernameAvailabilityChecker 的不同实现来实际查询数据库。

请记住,有很多很多技术可以解决此类测试问题,而且我给出的示例既简单又做作。

关于unit-testing - 如何对具有数据库访问权限的方法进行单元测试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19937667/

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