aspnetcore/test/Microsoft.AspNet.Mvc.Functi.../Logging/LoggingActionSelectionTest.cs

102 lines
4.2 KiB
C#

// 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.
#if DNX451 // Since Json.net serialization fails in CoreCLR
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Threading.Tasks;
using LoggingWebSite;
using Microsoft.AspNet.Builder;
using Microsoft.AspNet.Mvc.Logging;
using Microsoft.AspNet.TestHost;
using Newtonsoft.Json;
using Xunit;
namespace Microsoft.AspNet.Mvc.FunctionalTests
{
public class LoggingActionSelectionTest
{
private readonly IServiceProvider _services = TestHelper.CreateServices(nameof(LoggingWebSite));
private readonly Action<IApplicationBuilder> _app = new LoggingWebSite.Startup().Configure;
[Fact]
public async Task Successful_ActionSelection_Logged()
{
// Arrange
var server = TestServer.Create(_services, _app);
var client = server.CreateClient();
var requestTraceId = Guid.NewGuid().ToString();
// Act
var response = await client.GetAsync(string.Format(
"http://localhost/home/index?{0}={1}",
LoggingExtensions.RequestTraceIdQueryKey,
requestTraceId));
// Assert
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
var responseData = await response.Content.ReadAsStringAsync();
Assert.Equal("Home.Index", responseData);
var logs = await GetLogsAsync(client, requestTraceId);
var scopeNode = logs.FindScope(nameof(MvcRouteHandler) + ".RouteAsync");
Assert.NotNull(scopeNode);
var logInfo = scopeNode.Messages.OfDataType<MvcRouteHandlerRouteAsyncValues>()
.FirstOrDefault();
Assert.NotNull(logInfo);
Assert.NotNull(logInfo.State);
dynamic actionSelection = logInfo.State;
Assert.True((bool)actionSelection.ActionSelected);
Assert.True((bool)actionSelection.ActionInvoked);
Assert.True((bool)actionSelection.Handled);
}
[Fact]
public async Task Failed_ActionSelection_Logged()
{
// Arrange
var server = TestServer.Create(_services, _app);
var client = server.CreateClient();
var requestTraceId = Guid.NewGuid().ToString();
// Act
var response = await client.GetAsync(string.Format(
"http://localhost/InvalidController/InvalidAction?{0}={1}",
LoggingExtensions.RequestTraceIdQueryKey,
requestTraceId));
// Assert
Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
var logs = await GetLogsAsync(client, requestTraceId);
var scopeNode = logs.FindScope(nameof(MvcRouteHandler) + ".RouteAsync");
Assert.NotNull(scopeNode);
var logInfo = scopeNode.Messages.OfDataType<MvcRouteHandlerRouteAsyncValues>()
.FirstOrDefault();
Assert.NotNull(logInfo);
dynamic actionSelection = logInfo.State;
Assert.False((bool)actionSelection.ActionSelected);
Assert.False((bool)actionSelection.ActionInvoked);
Assert.False((bool)actionSelection.Handled);
}
private async Task<IEnumerable<ActivityContextDto>> GetLogsAsync(HttpClient client,
string requestTraceId)
{
var responseData = await client.GetStringAsync("http://localhost/logs");
var logActivities = JsonConvert.DeserializeObject<List<ActivityContextDto>>(responseData);
return logActivities.FilterByRequestTraceId(requestTraceId);
}
}
}
#endif