私は、Hanselman のブログにある MvcMockHelpers クラスを使用して、モック化された HttpContext を渡してきました。必要な認証データを追加するために多少拡張しましたが、ほとんどの場合、これは素晴らしいものでした.
私たちが抱えている問題は、コントローラーに与えているコンテキストの HttpContext.Response.Output に null 値が含まれていることです。これにより、いくつかの例外がスローされます。これを機能させるために何を追加すればよいかわかりません。
以下は、既存の FakeHttpConext() メソッドです。
public static HttpContextBase FakeHttpContext()
{
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>();
// Our identity additions ...
var user = new Mock<IPrincipal>();
OurIdentity identity = (OurIdentity)Thread.CurrentPrincipal.Identity;
context.Expect(ctx => ctx.Request).Returns(request.Object);
context.Expect(ctx => ctx.Response).Returns(response.Object);
context.Expect(ctx => ctx.Session).Returns(session.Object);
context.Expect(ctx => ctx.Server).Returns(server.Object);
context.Expect(ctx => ctx.User).Returns(user.Object);
context.Expect(ctx => ctx.User.Identity).Returns(identity);
return context.Object;
}
これは爆発メソッドです (MVC Contrib プロジェクトの XmlResult の一部です):
public override void ExecuteResult(ControllerContext context)
{
if (_objectToSerialize != null)
{
var xs = new XmlSerializer(_objectToSerialize.GetType());
context.HttpContext.Response.ContentType = "text/xml";
xs.Serialize(context.HttpContext.Response.Output, _objectToSerialize);
}
}
context.HttpContext.Response.Output が参照されたときに null 例外を防ぐために、FakeHttpContext メソッドに何を追加する必要がありますか?
明確化: 私が探しているソリューションは、Rhino ではなく Moq で実行する必要があります。質問のタイトルでMoqについて言及しましたが、質問の本文ではそれを無視しました。混乱して申し訳ありません。
解決策 次の 2 行のコードを FakeHttpContext() メソッドに追加しました。
var writer = new StringWriter();
context.Expect(ctx => ctx.Response.Output).Returns(writer);
これにより、null 例外が防止されます。長期的には良い答えかどうかはわかりませんが、今のところうまくいきます.