// ReSharper disable RedundantUsingDirective using System; using System.Collections.Generic; using System.Linq; using NLog; using NLog.Targets; using NUnit.Framework; namespace NzbDrone.Test.Common { public class ExceptionVerification : Target { private static List<LogEventInfo> _logs = new List<LogEventInfo>(); protected override void Write(LogEventInfo logEvent) { if (logEvent.Level >= LogLevel.Warn) { _logs.Add(logEvent); } } public static void Reset() { _logs = new List<LogEventInfo>(); } public static void AssertNoUnexcpectedLogs() { ExpectedFatals(0); ExpectedErrors(0); ExpectedWarns(0); } private static string GetLogsString(IEnumerable<LogEventInfo> logs) { string errors = ""; foreach (var log in logs) { string exception = ""; if (log.Exception != null) { exception = String.Format("[{0}: {1}]", log.Exception.GetType(), log.Exception.Message); } errors += Environment.NewLine + String.Format("[{0}] {1}: {2} {3}", log.Level, log.LoggerName, log.FormattedMessage, exception); } return errors; } public static void ExpectedErrors(int count) { Expected(LogLevel.Error, count); } public static void ExpectedFatals(int count) { Expected(LogLevel.Fatal, count); } public static void ExpectedWarns(int count) { Expected(LogLevel.Warn, count); } public static void IgnoreWarns() { Ignore(LogLevel.Warn); } public static void IgnoreErrors() { Ignore(LogLevel.Error); } public static void MarkInconclusive(Type exception) { var inconclusiveLogs = _logs.Where(l => l.Exception != null && l.Exception.GetType() == exception).ToList(); if (inconclusiveLogs.Any()) { inconclusiveLogs.ForEach(c => _logs.Remove(c)); Assert.Inconclusive(GetLogsString(inconclusiveLogs)); } } public static void MarkInconclusive(string text) { var inconclusiveLogs = _logs.Where(l => l.FormattedMessage.ToLower().Contains(text.ToLower())).ToList(); if (inconclusiveLogs.Any()) { inconclusiveLogs.ForEach(c => _logs.Remove(c)); Assert.Inconclusive(GetLogsString(inconclusiveLogs)); } } private static void Expected(LogLevel level, int count) { var levelLogs = _logs.Where(l => l.Level == level).ToList(); if (levelLogs.Count != count) { var message = String.Format("{0} {1}(s) were expected but {2} were logged.\n\r{3}", count, level, levelLogs.Count, GetLogsString(levelLogs)); message = "\n\r****************************************************************************************\n\r" + message + "\n\r****************************************************************************************"; Assert.Fail(message); } levelLogs.ForEach(c => _logs.Remove(c)); } private static void Ignore(LogLevel level) { var levelLogs = _logs.Where(l => l.Level == level).ToList(); levelLogs.ForEach(c => _logs.Remove(c)); } } }