seb-win-refactoring/SafeExamBrowser.Core.UnitTests/Logging/DefaultLogFormatterTests.cs

52 lines
1.4 KiB
C#

/*
* Copyright (c) 2017 ETH Zürich, Educational Development and Technology (LET)
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
using System;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using SafeExamBrowser.Contracts.Logging;
using SafeExamBrowser.Core.Logging;
namespace SafeExamBrowser.Core.UnitTests.Logging
{
[TestClass]
public class DefaultLogFormatterTests
{
[TestMethod]
[ExpectedException(typeof(NotImplementedException))]
public void MustReportNotYetImplementedLogContent()
{
var sut = new DefaultLogFormatter();
sut.Format(new NewLogContentType());
}
[TestMethod]
public void MustReturnRawTextForLogMessage()
{
var sut = new DefaultLogFormatter();
var entry = new LogText("Must return this text...");
var text = sut.Format(entry);
Assert.AreEqual(entry.Text, text);
}
[TestMethod]
public void MustCorrectlyFormatLogMessage()
{
var sut = new DefaultLogFormatter();
var date = new DateTime(2017, 10, 10, 15, 24, 38);
var threadInfo = new ThreadInfo(1234, "ABC");
var entry = new LogMessage(date, LogLevel.Warning, "Here's a warning message...", threadInfo);
var text = sut.Format(entry);
Assert.AreEqual($"2017-10-10 15:24:38.000 [1234: ABC] - WARNING: Here's a warning message...", text);
}
}
}