Added HttpNotFoundObjectResult and added relevant tests
This commit is contained in:
parent
5bb69e495e
commit
dc49a2c194
|
|
@ -0,0 +1,23 @@
|
|||
// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved.
|
||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||
|
||||
using Microsoft.AspNet.WebUtilities;
|
||||
|
||||
namespace Microsoft.AspNet.Mvc
|
||||
{
|
||||
/// <summary>
|
||||
/// An <see cref="ObjectResult"/> that when executed will produce a Not Found (404) response.
|
||||
/// </summary>
|
||||
public class HttpNotFoundObjectResult : ObjectResult
|
||||
{
|
||||
/// <summary>
|
||||
/// Creates a new <see cref="HttpNotFoundObjectResult"/> instance.
|
||||
/// </summary>
|
||||
/// <param name="value">The value to format in the entity body.</param>
|
||||
public HttpNotFoundObjectResult(object value)
|
||||
: base(value)
|
||||
{
|
||||
StatusCode = StatusCodes.Status404NotFound;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -692,6 +692,16 @@ namespace Microsoft.AspNet.Mvc
|
|||
return new HttpNotFoundResult();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates an <see cref="HttpNotFoundObjectResult"/> that produces a Not Found (404) response.
|
||||
/// </summary>
|
||||
/// <returns>The created <see cref="HttpNotFoundObjectResult"/> for the response.</returns>
|
||||
[NonAction]
|
||||
public virtual HttpNotFoundObjectResult HttpNotFound(object value)
|
||||
{
|
||||
return new HttpNotFoundObjectResult(value);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates an <see cref="BadRequestResult"/> that produces a Bad Request (400) response.
|
||||
/// </summary>
|
||||
|
|
|
|||
|
|
@ -0,0 +1,139 @@
|
|||
// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved.
|
||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.AspNet.Http;
|
||||
using Microsoft.AspNet.Http.Core;
|
||||
using Microsoft.AspNet.Routing;
|
||||
using Microsoft.AspNet.WebUtilities;
|
||||
using Microsoft.Framework.DependencyInjection;
|
||||
using Microsoft.Framework.DependencyInjection.Fallback;
|
||||
using Microsoft.Framework.OptionsModel;
|
||||
using Moq;
|
||||
using Xunit;
|
||||
|
||||
namespace Microsoft.AspNet.Mvc
|
||||
{
|
||||
public class HttpNotFoundObjectResultTest
|
||||
{
|
||||
[Fact]
|
||||
public void HttpNotFoundObjectResult_InitializesStatusCode()
|
||||
{
|
||||
// Arrange & act
|
||||
var notFound = new HttpNotFoundObjectResult(null);
|
||||
|
||||
// Assert
|
||||
Assert.Equal(StatusCodes.Status404NotFound, notFound.StatusCode);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void HttpNotFoundObjectResult_InitializesStatusCodeAndResponseContent()
|
||||
{
|
||||
// Arrange & act
|
||||
var notFound = new HttpNotFoundObjectResult("Test Content");
|
||||
|
||||
// Assert
|
||||
Assert.Equal(StatusCodes.Status404NotFound, notFound.StatusCode);
|
||||
Assert.Equal("Test Content", notFound.Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task HttpNotFoundObjectResult_ExecuteSuccessful()
|
||||
{
|
||||
// Arrange
|
||||
var input = "Test Content";
|
||||
var stream = new MemoryStream();
|
||||
|
||||
var httpResponse = new Mock<HttpResponse>();
|
||||
var tempContentType = string.Empty;
|
||||
httpResponse.SetupProperty(o => o.ContentType);
|
||||
httpResponse.SetupGet(r => r.Body).Returns(stream);
|
||||
|
||||
var actionContext = CreateMockActionContext(httpResponse.Object);
|
||||
var notFound = new HttpNotFoundObjectResult(input);
|
||||
|
||||
// Act
|
||||
await notFound.ExecuteResultAsync(actionContext);
|
||||
|
||||
// Assert
|
||||
httpResponse.VerifySet(r => r.StatusCode = StatusCodes.Status404NotFound);
|
||||
Assert.Equal(input.Length, httpResponse.Object.Body.Length);
|
||||
}
|
||||
|
||||
private static ActionContext CreateMockActionContext(
|
||||
HttpResponse response = null,
|
||||
string requestAcceptHeader = "application/*",
|
||||
string requestContentType = "application/json",
|
||||
string requestAcceptCharsetHeader = "",
|
||||
bool respectBrowserAcceptHeader = false)
|
||||
{
|
||||
var formatters = new IOutputFormatter[] { new StringOutputFormatter(), new JsonOutputFormatter() };
|
||||
var httpContext = new Mock<HttpContext>();
|
||||
if (response != null)
|
||||
{
|
||||
httpContext.Setup(o => o.Response).Returns(response);
|
||||
}
|
||||
|
||||
var content = "{name: 'Person Name', Age: 'not-an-age'}";
|
||||
var contentBytes = Encoding.UTF8.GetBytes(content);
|
||||
|
||||
var request = new DefaultHttpContext().Request;
|
||||
request.Headers["Accept-Charset"] = requestAcceptCharsetHeader;
|
||||
request.Headers["Accept"] = requestAcceptHeader;
|
||||
request.ContentType = requestContentType;
|
||||
request.Body = new MemoryStream(contentBytes);
|
||||
|
||||
httpContext.Setup(o => o.Request).Returns(request);
|
||||
httpContext.Setup(o => o.RequestServices).Returns(GetServiceProvider());
|
||||
httpContext.Setup(o => o.RequestServices.GetService(typeof(IOutputFormattersProvider)))
|
||||
.Returns(new TestOutputFormatterProvider(formatters));
|
||||
|
||||
var options = new Mock<IOptions<MvcOptions>>();
|
||||
options.SetupGet(o => o.Options)
|
||||
.Returns(new MvcOptions()
|
||||
{
|
||||
RespectBrowserAcceptHeader = respectBrowserAcceptHeader
|
||||
});
|
||||
httpContext.Setup(o => o.RequestServices.GetService(typeof(IOptions<MvcOptions>)))
|
||||
.Returns(options.Object);
|
||||
|
||||
return new ActionContext(httpContext.Object, new RouteData(), new ActionDescriptor());
|
||||
}
|
||||
|
||||
private static IServiceProvider GetServiceProvider()
|
||||
{
|
||||
var optionsSetup = new MvcOptionsSetup();
|
||||
var options = new MvcOptions();
|
||||
optionsSetup.Configure(options);
|
||||
var optionsAccessor = new Mock<IOptions<MvcOptions>>();
|
||||
optionsAccessor.SetupGet(o => o.Options).Returns(options);
|
||||
|
||||
var serviceCollection = new ServiceCollection();
|
||||
serviceCollection.AddInstance<IOptions<MvcOptions>>(optionsAccessor.Object);
|
||||
return serviceCollection.BuildServiceProvider();
|
||||
}
|
||||
|
||||
private class TestOutputFormatterProvider : IOutputFormattersProvider
|
||||
{
|
||||
private readonly IEnumerable<IOutputFormatter> _formatters;
|
||||
|
||||
public TestOutputFormatterProvider(IEnumerable<IOutputFormatter> formatters)
|
||||
{
|
||||
_formatters = formatters;
|
||||
}
|
||||
|
||||
public IReadOnlyList<IOutputFormatter> OutputFormatters
|
||||
{
|
||||
get
|
||||
{
|
||||
return _formatters.ToList();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -657,6 +657,21 @@ namespace Microsoft.AspNet.Mvc.Test
|
|||
Assert.Equal(StatusCodes.Status404NotFound, result.StatusCode);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void HttpNotFound_SetsStatusCodeAndResponseContent()
|
||||
{
|
||||
// Arrange
|
||||
var controller = new TestableController();
|
||||
|
||||
// Act
|
||||
var result = controller.HttpNotFound("Test Content");
|
||||
|
||||
// Assert
|
||||
Assert.IsType<HttpNotFoundObjectResult>(result);
|
||||
Assert.Equal(StatusCodes.Status404NotFound, result.StatusCode);
|
||||
Assert.Equal("Test Content", result.Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void BadRequest_SetsStatusCode()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -214,6 +214,23 @@ namespace Microsoft.AspNet.Mvc
|
|||
Assert.Equal(StatusCodes.Status404NotFound, httpNotFoundResult.StatusCode);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void ControllerHttpNotFoundObject_InvokedInUnitTests()
|
||||
{
|
||||
// Arrange
|
||||
var controller = new TestabilityController();
|
||||
|
||||
// Act
|
||||
var result = controller.HttpNotFoundObject_Action("Test Content");
|
||||
|
||||
// Assert
|
||||
Assert.NotNull(result);
|
||||
|
||||
var httpNotFoundObjectResult = Assert.IsType<HttpNotFoundObjectResult>(result);
|
||||
Assert.Equal(StatusCodes.Status404NotFound, httpNotFoundObjectResult.StatusCode);
|
||||
Assert.Equal("Test Content", httpNotFoundObjectResult.Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void ControllerHttpBadRequest_InvokedInUnitTests()
|
||||
{
|
||||
|
|
@ -621,6 +638,11 @@ namespace Microsoft.AspNet.Mvc
|
|||
{
|
||||
return HttpNotFound();
|
||||
}
|
||||
|
||||
public IActionResult HttpNotFoundObject_Action(object value)
|
||||
{
|
||||
return HttpNotFound(value);
|
||||
}
|
||||
}
|
||||
|
||||
private class MyModel
|
||||
|
|
|
|||
|
|
@ -284,5 +284,45 @@ namespace Microsoft.AspNet.Mvc.FunctionalTests
|
|||
// Assert
|
||||
Assert.Equal(HttpStatusCode.Created, response.StatusCode);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task HttpNotFoundObjectResult_NoResponseContent()
|
||||
{
|
||||
// Arrange
|
||||
var server = TestServer.Create(_provider, _app);
|
||||
var client = server.CreateClient();
|
||||
|
||||
var request = new HttpRequestMessage(
|
||||
HttpMethod.Get,
|
||||
"http://localhost/ActionResultsVerification/GetNotFoundObjectResult");
|
||||
|
||||
// Act
|
||||
var response = await client.SendAsync(request);
|
||||
|
||||
// Assert
|
||||
Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
|
||||
Assert.Equal("", await response.Content.ReadAsStringAsync());
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task HttpNotFoundObjectResult_WithResponseContent()
|
||||
{
|
||||
// Arrange
|
||||
var server = TestServer.Create(_provider, _app);
|
||||
var client = server.CreateClient();
|
||||
var input = "{\"SampleInt\":10}";
|
||||
|
||||
var request = new HttpRequestMessage(
|
||||
HttpMethod.Post,
|
||||
"http://localhost/ActionResultsVerification/GetNotFoundObjectResultWithContent");
|
||||
request.Content = new StringContent(input, Encoding.UTF8, "application/json");
|
||||
|
||||
// Act
|
||||
var response = await client.SendAsync(request);
|
||||
|
||||
// Assert
|
||||
Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
|
||||
Assert.Equal("{\"SampleInt\":10,\"SampleString\":\"Foo\"}", await response.Content.ReadAsStringAsync());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -85,6 +85,16 @@ namespace ActionResultsWebSite
|
|||
return result;
|
||||
}
|
||||
|
||||
public IActionResult GetNotFoundObjectResult()
|
||||
{
|
||||
return HttpNotFound(null);
|
||||
}
|
||||
|
||||
public IActionResult GetNotFoundObjectResultWithContent()
|
||||
{
|
||||
return HttpNotFound(CreateDummy());
|
||||
}
|
||||
|
||||
public DummyClass GetDummy(int id)
|
||||
{
|
||||
return CreateDummy();
|
||||
|
|
|
|||
Loading…
Reference in New Issue