我正在以测试驱动的方式使用 ASP.NET MVC 解决方案,我想使用表单身份验证将用户登录到我的应用程序。我想在控制器中结束的代码如下所示:
FormsAuthentication.SetAuthCookie(userName, false);
我的问题是如何编写测试来证明此代码的合理性?
有没有办法检查是否使用正确的参数调用了 SetAuthCookie 方法?
有没有办法注入一个假的/模拟的 FormsAuthentication?
我正在以测试驱动的方式使用 ASP.NET MVC 解决方案,我想使用表单身份验证将用户登录到我的应用程序。我想在控制器中结束的代码如下所示:
FormsAuthentication.SetAuthCookie(userName, false);
我的问题是如何编写测试来证明此代码的合理性?
有没有办法检查是否使用正确的参数调用了 SetAuthCookie 方法?
有没有办法注入一个假的/模拟的 FormsAuthentication?
我将首先编写一个接口和一个封装此逻辑的包装类,然后在我的控制器中使用该接口:
public interface IAuth
{
void DoAuth(string userName, bool remember);
}
public class FormsAuthWrapper : IAuth
{
public void DoAuth(string userName, bool remember)
{
FormsAuthentication.SetAuthCookie(userName, remember);
}
}
public class MyController : Controller
{
private readonly IAuth _auth;
public MyController(IAuth auth)
{
_auth = auth;
}
}
现在IAuth
可以在单元测试中轻松地模拟并验证控制器是否调用了预期的方法。我不会对这个FormsAuthWrapper
类进行单元测试,因为它只是将调用委托给FormsAuthentication
它应该做的事情(微软保证:-))。