私は偽の HttpContext (最後に提供されるコード) を使用していますが、TempData コレクション (SetFakeControllerContext メソッドの 4 行目) にアクセスできないため、おそらく何かが不足しています。試行するたびに、次のエラー メッセージが表示されます。
「controller.TempData」が「System.AccessViolationException」タイプの例外をスローしました
FakeHttpContext を呼び出すコードは次のとおりです。
public static void SetFakeControllerContext(this Controller controller)
{
HttpContextBase httpContext = FakeHttpContext(string.Empty);
var context = new ControllerContext(new RequestContext(httpContext, new RouteData()), controller);
controller.ControllerContext = context;
controller.TempData = new TempDataDictionary(); //This is not necessary! It was just a test!!!!
}
私が間違っていることを誰かが知っていますか?
public static HttpContextBase FakeHttpContext(string username){
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);
if (!string.IsNullOrEmpty(username))
{
identity.Setup(id => id.IsAuthenticated).Returns(true);
identity.Setup(id => id.Name).Returns(username);
}
else
{
identity.Setup(id => id.IsAuthenticated).Returns(false);
identity.Setup(id => id.Name).Returns(string.Empty);
}
context.Setup(ctx => ctx.Response.Cache).Returns(CreateCachePolicy());
return context.Object;
}
Ps: 私は Moq を使用しています
更新:
ああ、神様!!信じられない!問題が間違った MVC dll への参照であったことを突き止めるのに 2 時間以上かかりました。メインアプリでは System.Web.Mvc 2.0 を参照していましたが、別のプロジェクトでは System.Web.Mvc 1.0 を参照していました。これにつきましては申し訳ございません!