最小起订量代码:
mockControllerContext.SetupGet(x => x.HttpContext.Session["User"]).Returns(new User
{
Name = "Moto",
IsAdmin = true
});
taskController.ControllerContext = mockControllerContext.Object;
如何使用 MS Fakes 来模拟 HttpContext.Session???
在一个类中从这里获得这两个函数;
public static class HttpContextFactory
{
public static void SetFakeAuthenticatedControllerContext(this Controller controller)
{
var httpContext = FakeAuthenticatedHttpContext();
ControllerContext context =
new ControllerContext(
new RequestContext(httpContext,
new RouteData()), controller);
controller.ControllerContext = context;
}
private static HttpContextBase FakeAuthenticatedHttpContext()
{
var context = new Mock<HttpContextBase>();
var request = new Mock<HttpRequestBase>();
var response = new Mock<HttpResponseBase>();
var session = new Mock<HttpSessionStateBase>();
var server = new Mock<HttpServerUtilityBase>();
var user = new Mock<IPrincipal>();
var identity = new Mock<IIdentity>();
context.Setup(ctx => ctx.Request).Returns(request.Object);
context.Setup(ctx => ctx.Response).Returns(response.Object);
context.Setup(ctx => ctx.Session).Returns(session.Object);
context.Setup(ctx => ctx.Server).Returns(server.Object);
context.Setup(ctx => ctx.User).Returns(user.Object);
user.Setup(ctx => ctx.Identity).Returns(identity.Object);
identity.Setup(id => id.IsAuthenticated).Returns(true);
identity.Setup(id => id.Name).Returns("a.ali174");
return context.Object;
}
}
从单元测试中,我这样称呼它们;
HttpContextFactory.SetFakeAuthenticatedControllerContext(controller);
您可以使用
填充程序与Microsoft假货一起使用。 但是,我发现这是一种不好的做法。 相反,您应该通过将第三方库包装在您自己的类中来将自己与第三方库隔离开来。 然后,您可以在该类上放置一个接口,并在整个代码中使用您的接口。 此防腐层允许您保护自己免受第三方程序集的影响,并且在第三方程序集更改时受到的影响较小。
如果你想了解更多关于使用填充码的信息,你可以看看我在Microsoft Fakes上撰写的这个Pluralsight课程。 (完全披露:我在这门课程中获得版税,但这是一种快速上手的方法)