Files
Umbraco-CMS/tests/Umbraco.Tests.Common/TestHelpers/LogTestHelper.cs
Paul Johnson 00133e880d Move test projects from src/ to tests/ (#11357)
* Update gitignore

* Move csproj

* Update project references

* Update solutions

* Update build scripts

* Tests used to share editorconfig with projects in src

* Fix broken tests.

* Stop copying around .editorconfig

merged root one with linting

* csharp_style_expression_bodied -> suggestion

* Move StyleCop rulesets to matching directories and update shared build properties

* Remove legacy build files, update NuGet.cofig and solution files

* Restore myget source

* Clean up .gitignore

* Update .gitignore

* Move new test classes to tests after merge

* Gitignore + nuget config

* Move new test

Co-authored-by: Ronald Barendse <ronald@barend.se>
2021-10-18 08:14:04 +01:00

42 lines
1.3 KiB
C#

// Copyright (c) Umbraco.
// See LICENSE for more details.
using System;
using Microsoft.Extensions.Logging;
using Moq;
namespace Umbraco.Cms.Tests.Common.TestHelpers
{
public static class LogTestHelper
{
public static Mock<ILogger<T>> VerifyLogError<T>(
this Mock<ILogger<T>> logger,
Exception exception,
string expectedMessage,
Times? times = null) => VerifyLogging(logger, exception, expectedMessage, LogLevel.Error, times);
private static Mock<ILogger<T>> VerifyLogging<T>(
this Mock<ILogger<T>> logger,
Exception exception,
string expectedMessage,
LogLevel expectedLogLevel = LogLevel.Debug,
Times? times = null)
{
times ??= Times.Once();
Func<object, Type, bool> state = (v, t) =>
string.Compare(v.ToString(), expectedMessage, StringComparison.Ordinal) == 0;
logger.Verify(
x => x.Log(
It.Is<LogLevel>(l => l == expectedLogLevel),
It.IsAny<EventId>(),
It.Is<It.IsAnyType>((v, t) => state(v, t)),
exception,
It.Is<Func<It.IsAnyType, Exception, string>>((v, t) => true)), (Times)times);
return logger;
}
}
}