|
|
|
using System;
|
|
|
|
using System.Linq;
|
|
|
|
using FluentAssertions;
|
|
|
|
using NUnit.Framework;
|
|
|
|
|
|
|
|
namespace NzbDrone.Integration.Test
|
|
|
|
{
|
|
|
|
[TestFixture]
|
|
|
|
public class HttpLogFixture : IntegrationTest
|
|
|
|
{
|
|
|
|
[Test]
|
|
|
|
public void should_log_on_error()
|
|
|
|
{
|
|
|
|
var config = HostConfig.Get(1);
|
|
|
|
config.LogLevel = "Trace";
|
|
|
|
HostConfig.Put(config);
|
|
|
|
|
|
|
|
var resultGet = Author.All();
|
|
|
|
|
|
|
|
var logFile = "Readarr.trace.txt";
|
|
|
|
var logLines = Logs.GetLogFileLines(logFile);
|
|
|
|
|
|
|
|
var result = Author.InvalidPost(new Readarr.Api.V1.Author.AuthorResource());
|
|
|
|
|
|
|
|
// Skip 2 and 1 to ignore the logs endpoint
|
|
|
|
logLines = Logs.GetLogFileLines(logFile).Skip(logLines.Length + 2).ToArray();
|
|
|
|
Array.Resize(ref logLines, logLines.Length - 1);
|
|
|
|
|
|
|
|
logLines.Should().Contain(v => v.Contains("|Trace|Http|Req") && v.Contains("/api/v1/author/"));
|
|
|
|
logLines.Should().Contain(v => v.Contains("|Trace|Http|Res") && v.Contains("/api/v1/author/: 400.BadRequest"));
|
|
|
|
logLines.Should().Contain(v => v.Contains("|Debug|Api|") && v.Contains("/api/v1/author/: 400.BadRequest"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|