2018-10-12 15:23:43 +02:00
|
|
|
|
/*
|
2019-01-09 11:25:21 +01:00
|
|
|
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
2018-10-12 15:23:43 +02:00
|
|
|
|
*
|
|
|
|
|
* 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;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Configuration.Contracts;
|
|
|
|
|
using SafeExamBrowser.Configuration.Contracts.Settings;
|
|
|
|
|
using SafeExamBrowser.Core.Contracts.OperationModel;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2018-10-12 15:23:43 +02:00
|
|
|
|
using SafeExamBrowser.Runtime.Operations;
|
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
|
|
|
|
{
|
|
|
|
|
[TestClass]
|
|
|
|
|
public class SessionActivationOperationTests
|
|
|
|
|
{
|
2019-06-11 09:53:33 +02:00
|
|
|
|
private SessionConfiguration currentSession;
|
2018-10-12 15:23:43 +02:00
|
|
|
|
private Mock<ILogger> logger;
|
2019-06-11 09:53:33 +02:00
|
|
|
|
private SessionConfiguration nextSession;
|
2019-02-12 10:34:39 +01:00
|
|
|
|
private Settings nextSettings;
|
2018-10-12 15:23:43 +02:00
|
|
|
|
private SessionContext sessionContext;
|
|
|
|
|
|
|
|
|
|
private SessionActivationOperation sut;
|
|
|
|
|
|
|
|
|
|
[TestInitialize]
|
|
|
|
|
public void Initialize()
|
|
|
|
|
{
|
2019-06-11 09:53:33 +02:00
|
|
|
|
currentSession = new SessionConfiguration();
|
2018-10-12 15:23:43 +02:00
|
|
|
|
logger = new Mock<ILogger>();
|
2019-06-11 09:53:33 +02:00
|
|
|
|
nextSession = new SessionConfiguration();
|
2019-02-12 10:34:39 +01:00
|
|
|
|
nextSettings = new Settings();
|
2018-10-12 15:23:43 +02:00
|
|
|
|
sessionContext = new SessionContext();
|
|
|
|
|
|
2019-06-11 09:53:33 +02:00
|
|
|
|
nextSession.Settings = nextSettings;
|
|
|
|
|
sessionContext.Current = currentSession;
|
|
|
|
|
sessionContext.Next = nextSession;
|
2018-10-12 15:23:43 +02:00
|
|
|
|
|
|
|
|
|
sut = new SessionActivationOperation(logger.Object, sessionContext);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-02-26 10:07:41 +01:00
|
|
|
|
public void Perform_MustCorrectlyActivateFirstSession()
|
2018-10-12 15:23:43 +02:00
|
|
|
|
{
|
|
|
|
|
sessionContext.Current = null;
|
|
|
|
|
|
|
|
|
|
var result = sut.Perform();
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
2019-06-11 09:53:33 +02:00
|
|
|
|
Assert.AreSame(sessionContext.Current, nextSession);
|
2018-10-12 15:23:43 +02:00
|
|
|
|
Assert.IsNull(sessionContext.Next);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-02-26 10:07:41 +01:00
|
|
|
|
public void Perform_MustCorrectlySwitchLogSeverity()
|
|
|
|
|
{
|
|
|
|
|
nextSettings.LogLevel = LogLevel.Info;
|
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
|
|
|
|
logger.VerifySet(l => l.LogLevel = It.Is<LogLevel>(ll => ll == nextSettings.LogLevel));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Repeat_MustCorrectlySwitchSession()
|
2018-10-12 15:23:43 +02:00
|
|
|
|
{
|
|
|
|
|
var result = sut.Repeat();
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
2019-06-11 09:53:33 +02:00
|
|
|
|
Assert.AreSame(sessionContext.Current, nextSession);
|
2018-10-12 15:23:43 +02:00
|
|
|
|
Assert.IsNull(sessionContext.Next);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-02-26 10:07:41 +01:00
|
|
|
|
public void Repeat_MustCorrectlySwitchLogSeverity()
|
|
|
|
|
{
|
|
|
|
|
nextSettings.LogLevel = LogLevel.Warning;
|
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
|
|
|
|
logger.VerifySet(l => l.LogLevel = It.Is<LogLevel>(ll => ll == nextSettings.LogLevel));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustAlwaysCompleteSuccessfully()
|
2018-10-12 15:23:43 +02:00
|
|
|
|
{
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|