Ответ 1
HttpContext доступен только для чтения, но он фактически получен из ControllerContext, который вы можете установить.
controller.ControllerContext = new ControllerContext( context.Object, new RouteData(), controller );
[TestMethod]
public void Home_Message_Display_Unknown_User_when_coockie_does_not_exist()
{
var context = new Mock<HttpContextBase>();
var request = new Mock<HttpRequestBase>();
context
.Setup(c => c.Request)
.Returns(request.Object);
HomeController controller = new HomeController();
controller.HttpContext = context; //Here I am getting an error (read only).
...
}
у моего базового контроллера есть переопределение инициализации, которая получает этот запрос. Я пытаюсь передать это, но я ничего не делаю правильно.
protected override void Initialize(System.Web.Routing.RequestContext requestContext)
{
base.Initialize(requestContext);
}
Где я могу получить дополнительную информацию о насмехании моего RequestContext и HttpContext с помощью Moq? Я пытаюсь высмеять куки и общий контекст.
HttpContext доступен только для чтения, но он фактически получен из ControllerContext, который вы можете установить.
controller.ControllerContext = new ControllerContext( context.Object, new RouteData(), controller );
Создайте запрос, ответ и поместите их в HttpContext:
HttpRequest httpRequest = new HttpRequest("", "http://mySomething/", "");
StringWriter stringWriter = new StringWriter();
HttpResponse httpResponse = new HttpResponse(stringWriter);
HttpContext httpContextMock = new HttpContext(httpRequest, httpResponse);
Спасибо пользователю 0100110010101.
Это сработало для меня, и вот у меня возникла проблема при написании тестового кода для кода ниже:
var currentUrl = Request.Url.AbsoluteUri;
И вот линии, которые решили проблему
HomeController controller = new HomeController();
//Mock Request.Url.AbsoluteUri
HttpRequest httpRequest = new HttpRequest("", "http://mySomething", "");
StringWriter stringWriter = new StringWriter();
HttpResponse httpResponse = new HttpResponse(stringWriter);
HttpContext httpContextMock = new HttpContext(httpRequest, httpResponse);
controller.ControllerContext = new ControllerContext(new HttpContextWrapper(httpContextMock), new RouteData(), controller);
Может быть полезно для других.
Вот пример того, как вы можете установить это: Mocking HttpContext HttpRequest и HttpResponse для UnitTests (с использованием Moq)
Обратите внимание на методы расширения, которые действительно помогают упростить использование этих насмешливых классов:
var mockHttpContext = new API_Moq_HttpContext();
var httpContext = mockHttpContext.httpContext();
httpContext.request_Write("<html><body>".line());
httpContext.request_Write(" this is a web page".line());
httpContext.request_Write("</body></html>");
return httpContext.request_Read();
Вот пример того, как написать Unit Test с помощью moq, чтобы проверить, что HttpModule работает как ожидалось: Unit Test для HttpModule с использованием Moq to wrap HttpRequest
Обновление: этот API был реорганизован на
Вот как я использовал ControllerContext для передачи ложного пути приложения:
[TestClass]
public class ClassTest
{
private Mock<ControllerContext> mockControllerContext;
private HomeController sut;
[TestInitialize]
public void TestInitialize()
{
mockControllerContext = new Mock<ControllerContext>();
sut = new HomeController();
}
[TestCleanup]
public void TestCleanup()
{
sut.Dispose();
mockControllerContext = null;
}
[TestMethod]
public void Index_Should_Return_Default_View()
{
// Expectations
mockControllerContext.SetupGet(x => x.HttpContext.Request.ApplicationPath)
.Returns("/foo.com");
sut.ControllerContext = mockControllerContext.Object;
// Act
var failure = sut.Index();
// Assert
Assert.IsInstanceOfType(failure, typeof(ViewResult), "Index() did not return expected ViewResult.");
}
}