seb-win-refactoring/SafeExamBrowser.Client.UnitTests/Notifications/LogNotificationControllerTests.cs

73 lines
1.9 KiB
C#
Raw Normal View History

/*
2021-02-03 00:45:33 +01:00
* Copyright (c) 2021 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 Microsoft.VisualStudio.TestTools.UnitTesting;
using Moq;
using SafeExamBrowser.Client.Notifications;
using SafeExamBrowser.Logging.Contracts;
using SafeExamBrowser.UserInterface.Contracts;
using SafeExamBrowser.UserInterface.Contracts.Windows;
namespace SafeExamBrowser.Client.UnitTests.Notifications
{
[TestClass]
public class LogNotificationControllerTests
{
2019-04-04 16:06:05 +02:00
private Mock<ILogger> logger;
private Mock<IUserInterfaceFactory> uiFactory;
[TestInitialize]
public void Initialize()
{
2019-04-04 16:06:05 +02:00
logger = new Mock<ILogger>();
uiFactory = new Mock<IUserInterfaceFactory>();
}
[TestMethod]
public void MustCloseWindowWhenTerminating()
{
var window = new Mock<IWindow>();
2019-04-04 16:06:05 +02:00
var sut = new LogNotificationController(logger.Object, uiFactory.Object);
2019-04-04 16:06:05 +02:00
uiFactory.Setup(u => u.CreateLogWindow(It.IsAny<ILogger>())).Returns(window.Object);
sut.Activate();
sut.Terminate();
window.Verify(w => w.Close());
}
[TestMethod]
public void MustOpenOnlyOneWindow()
{
var window = new Mock<IWindow>();
2019-04-04 16:06:05 +02:00
var sut = new LogNotificationController(logger.Object, uiFactory.Object);
2019-04-04 16:06:05 +02:00
uiFactory.Setup(u => u.CreateLogWindow(It.IsAny<ILogger>())).Returns(window.Object);
sut.Activate();
sut.Activate();
sut.Activate();
sut.Activate();
sut.Activate();
2019-04-04 16:06:05 +02:00
uiFactory.Verify(u => u.CreateLogWindow(It.IsAny<ILogger>()), Times.Once);
window.Verify(u => u.Show(), Times.Once);
window.Verify(u => u.BringToForeground(), Times.Exactly(4));
}
2019-04-04 16:06:05 +02:00
[TestMethod]
public void MustNotFailToTerminateIfNotStarted()
{
var sut = new LogNotificationController(logger.Object, uiFactory.Object);
sut.Terminate();
}
}
}