/* * Copyright (c) 2019 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.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings; using SafeExamBrowser.Contracts.Core.OperationModel; using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Runtime.Operations; namespace SafeExamBrowser.Runtime.UnitTests.Operations { [TestClass] public class SessionActivationOperationTests { private Mock currentSession; private Mock logger; private Mock nextSession; private Settings nextSettings; private SessionContext sessionContext; private SessionActivationOperation sut; [TestInitialize] public void Initialize() { currentSession = new Mock(); logger = new Mock(); nextSession = new Mock(); nextSettings = new Settings(); sessionContext = new SessionContext(); nextSession.SetupGet(s => s.Settings).Returns(nextSettings); sessionContext.Current = currentSession.Object; sessionContext.Next = nextSession.Object; sut = new SessionActivationOperation(logger.Object, sessionContext); } [TestMethod] public void Perform_MustCorrectlyActivateFirstSession() { sessionContext.Current = null; var result = sut.Perform(); currentSession.VerifyNoOtherCalls(); nextSession.VerifyGet(s => s.Id); Assert.AreEqual(OperationResult.Success, result); Assert.AreSame(sessionContext.Current, nextSession.Object); Assert.IsNull(sessionContext.Next); } [TestMethod] public void Perform_MustCorrectlySwitchLogSeverity() { nextSettings.LogLevel = LogLevel.Info; sut.Perform(); logger.VerifySet(l => l.LogLevel = It.Is(ll => ll == nextSettings.LogLevel)); } [TestMethod] public void Repeat_MustCorrectlySwitchSession() { var result = sut.Repeat(); currentSession.VerifyGet(s => s.Id); nextSession.VerifyGet(s => s.Id); Assert.AreEqual(OperationResult.Success, result); Assert.AreSame(sessionContext.Current, nextSession.Object); Assert.IsNull(sessionContext.Next); } [TestMethod] public void Repeat_MustCorrectlySwitchLogSeverity() { nextSettings.LogLevel = LogLevel.Warning; sut.Perform(); logger.VerifySet(l => l.LogLevel = It.Is(ll => ll == nextSettings.LogLevel)); } [TestMethod] public void Revert_MustAlwaysCompleteSuccessfully() { var result = sut.Revert(); currentSession.VerifyNoOtherCalls(); nextSession.VerifyNoOtherCalls(); Assert.AreEqual(OperationResult.Success, result); } } }