2018-01-23 15:33:54 +01:00
|
|
|
|
/*
|
2024-03-05 18:37:42 +01:00
|
|
|
|
* Copyright (c) 2024 ETH Zürich, IT Services
|
2018-01-23 15:33:54 +01: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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2018-01-24 12:34:32 +01:00
|
|
|
|
using System;
|
2019-06-18 10:18:56 +02:00
|
|
|
|
using System.Threading;
|
2018-01-23 15:33:54 +01:00
|
|
|
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
using Moq;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Communication.Contracts.Hosts;
|
|
|
|
|
using SafeExamBrowser.Communication.Contracts.Proxies;
|
|
|
|
|
using SafeExamBrowser.Configuration.Contracts;
|
|
|
|
|
using SafeExamBrowser.Core.Contracts.OperationModel;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2018-08-31 10:06:27 +02:00
|
|
|
|
using SafeExamBrowser.Runtime.Operations;
|
2019-06-11 11:45:05 +02:00
|
|
|
|
using SafeExamBrowser.Runtime.Operations.Events;
|
2019-12-10 14:22:18 +01:00
|
|
|
|
using SafeExamBrowser.Settings;
|
|
|
|
|
using SafeExamBrowser.Settings.Service;
|
2019-09-06 08:32:29 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Contracts;
|
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.MessageBox;
|
2018-01-23 15:33:54 +01:00
|
|
|
|
|
2018-08-31 10:06:27 +02:00
|
|
|
|
namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
2018-01-23 15:33:54 +01:00
|
|
|
|
{
|
|
|
|
|
[TestClass]
|
2018-03-21 15:28:59 +01:00
|
|
|
|
public class ServiceOperationTests
|
2018-01-23 15:33:54 +01:00
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
private SessionContext context;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
private Mock<ILogger> logger;
|
2019-06-06 15:44:03 +02:00
|
|
|
|
private Mock<IRuntimeHost> runtimeHost;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
private Mock<IServiceProxy> service;
|
2019-06-18 10:18:56 +02:00
|
|
|
|
private EventWaitHandle serviceEvent;
|
2019-06-21 15:05:31 +02:00
|
|
|
|
private Mock<IUserInfo> userInfo;
|
2018-03-21 10:23:15 +01:00
|
|
|
|
private ServiceOperation sut;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
|
|
|
|
[TestInitialize]
|
|
|
|
|
public void Initialize()
|
|
|
|
|
{
|
2019-06-18 10:18:56 +02:00
|
|
|
|
var serviceEventName = $"{nameof(SafeExamBrowser)}-{nameof(ServiceOperationTests)}";
|
|
|
|
|
|
2018-01-24 12:34:32 +01:00
|
|
|
|
logger = new Mock<ILogger>();
|
2019-06-06 15:44:03 +02:00
|
|
|
|
runtimeHost = new Mock<IRuntimeHost>();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
service = new Mock<IServiceProxy>();
|
2019-06-18 10:18:56 +02:00
|
|
|
|
serviceEvent = new EventWaitHandle(false, EventResetMode.AutoReset, serviceEventName);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context = new SessionContext();
|
2019-06-21 15:05:31 +02:00
|
|
|
|
userInfo = new Mock<IUserInfo>();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Current = new SessionConfiguration();
|
|
|
|
|
context.Current.AppConfig = new AppConfig();
|
|
|
|
|
context.Current.AppConfig.ServiceEventName = serviceEventName;
|
|
|
|
|
context.Current.Settings = new AppSettings();
|
|
|
|
|
context.Next = new SessionConfiguration();
|
|
|
|
|
context.Next.AppConfig = new AppConfig();
|
|
|
|
|
context.Next.AppConfig.ServiceEventName = serviceEventName;
|
|
|
|
|
context.Next.Settings = new AppSettings();
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
sut = new ServiceOperation(logger.Object, runtimeHost.Object, service.Object, context, 0, userInfo.Object);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Perform_MustConnectToService()
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2018-03-15 09:55:04 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Mandatory;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
2018-03-15 09:55:04 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Optional;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
2018-03-15 09:55:04 +01:00
|
|
|
|
service.Verify(s => s.Connect(null, true), Times.Exactly(2));
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2020-06-23 13:53:10 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Perform_MustNotConnectToServiceWithIgnoreSet()
|
|
|
|
|
{
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
|
|
|
|
context.Next.Settings.Service.IgnoreService = true;
|
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Mandatory;
|
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Optional;
|
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.Connect(null, true), Times.Never);
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-21 15:28:59 +01:00
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Perform_MustStartSessionIfConnected()
|
2018-03-21 15:28:59 +01:00
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.SessionId = Guid.NewGuid();
|
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Optional;
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
2018-03-21 15:28:59 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
var result = sut.Perform();
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.Verify(s => s.StartSession(It.Is<ServiceConfiguration>(c => c.SessionId == context.Next.SessionId)), Times.Once);
|
2019-07-04 09:12:28 +02:00
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Never);
|
2019-06-21 15:05:31 +02:00
|
|
|
|
userInfo.Verify(u => u.GetUserName(), Times.Once);
|
|
|
|
|
userInfo.Verify(u => u.GetUserSid(), Times.Once);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
2018-03-21 15:28:59 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Perform_MustFailIfSessionStartUnsuccessful()
|
2018-03-21 15:28:59 +01:00
|
|
|
|
{
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true));
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
var result = sut.Perform();
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-06-11 09:53:33 +02:00
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Once);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
2018-03-21 15:28:59 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-01-24 12:34:32 +01:00
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Perform_MustFailIfSessionNotStartedWithinTimeout()
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2019-06-06 15:44:03 +02:00
|
|
|
|
const int TIMEOUT = 50;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
var after = default(DateTime);
|
|
|
|
|
var before = default(DateTime);
|
|
|
|
|
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
2019-06-11 09:53:33 +02:00
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true));
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
sut = new ServiceOperation(logger.Object, runtimeHost.Object, service.Object, context, TIMEOUT, userInfo.Object);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
before = DateTime.Now;
|
|
|
|
|
var result = sut.Perform();
|
|
|
|
|
after = DateTime.Now;
|
|
|
|
|
|
2019-06-11 09:53:33 +02:00
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Once);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
Assert.IsTrue(after - before >= new TimeSpan(0, 0, 0, 0, TIMEOUT));
|
|
|
|
|
}
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Perform_MustNotStartSessionIfNotConnected()
|
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Mandatory;
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
2018-03-15 09:55:04 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
var result = sut.Perform();
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
2019-06-11 09:53:33 +02:00
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Never);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-11 11:45:05 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Perform_MustHandleCommunicationFailureWhenStartingSession()
|
|
|
|
|
{
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(false));
|
|
|
|
|
|
|
|
|
|
var result = sut.Perform();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Once);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-24 12:34:32 +01:00
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Perform_MustFailIfServiceMandatoryAndNotAvailable()
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2019-06-11 11:45:05 +02:00
|
|
|
|
var errorShown = false;
|
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Mandatory;
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
2018-03-15 09:55:04 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
2019-06-11 11:45:05 +02:00
|
|
|
|
sut.ActionRequired += (args) => errorShown = args is MessageEventArgs m && m.Icon == MessageBoxIcon.Error;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2018-02-28 15:49:06 +01:00
|
|
|
|
var result = sut.Perform();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2018-02-28 15:49:06 +01:00
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
2019-06-11 11:45:05 +02:00
|
|
|
|
Assert.IsTrue(errorShown);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Perform_MustNotFailIfServiceOptionalAndNotAvailable()
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Optional;
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
2018-03-15 09:55:04 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2018-02-28 15:49:06 +01:00
|
|
|
|
var result = sut.Perform();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Never);
|
|
|
|
|
|
2018-02-28 15:49:06 +01:00
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-11 11:45:05 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Perform_MustShowWarningIfServiceNotAvailableAndPolicyWarn()
|
|
|
|
|
{
|
|
|
|
|
var warningShown = false;
|
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Warn;
|
2019-06-11 11:45:05 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
|
|
|
|
sut.ActionRequired += (args) => warningShown = args is MessageEventArgs m && m.Icon == MessageBoxIcon.Warning;
|
|
|
|
|
|
|
|
|
|
var result = sut.Perform();
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
Assert.IsTrue(warningShown);
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-24 12:34:32 +01:00
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Repeat_MustStopCurrentAndStartNewSession()
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
var order = 0;
|
|
|
|
|
var start1 = 0;
|
|
|
|
|
var stop1 = 0;
|
|
|
|
|
var start2 = 0;
|
|
|
|
|
var session1Id = Guid.NewGuid();
|
|
|
|
|
var session2Id = Guid.NewGuid();
|
|
|
|
|
|
|
|
|
|
context.Next.SessionId = session1Id;
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
|
|
|
|
service
|
|
|
|
|
.Setup(s => s.StartSession(It.Is<ServiceConfiguration>(c => c.SessionId == session1Id)))
|
|
|
|
|
.Returns(new CommunicationResult(true))
|
|
|
|
|
.Callback(() => { start1 = ++order; serviceEvent.Set(); });
|
|
|
|
|
service
|
|
|
|
|
.Setup(s => s.StartSession(It.Is<ServiceConfiguration>(c => c.SessionId == session2Id)))
|
|
|
|
|
.Returns(new CommunicationResult(true))
|
|
|
|
|
.Callback(() => { start2 = ++order; serviceEvent.Set(); });
|
|
|
|
|
service
|
|
|
|
|
.Setup(s => s.StopSession(It.IsAny<Guid>()))
|
|
|
|
|
.Returns(new CommunicationResult(true))
|
|
|
|
|
.Callback(() => { stop1 = ++order; serviceEvent.Set(); });
|
|
|
|
|
|
|
|
|
|
sut.Perform();
|
|
|
|
|
|
|
|
|
|
context.Current.SessionId = session1Id;
|
|
|
|
|
context.Next.SessionId = session2Id;
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
var result = sut.Repeat();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.Verify(s => s.Connect(It.IsAny<Guid?>(), It.IsAny<bool>()), Times.Once);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.Verify(s => s.StopSession(It.Is<Guid>(id => id == session1Id)), Times.Once);
|
|
|
|
|
service.Verify(s => s.StartSession(It.Is<ServiceConfiguration>(c => c.SessionId == session1Id)), Times.Once);
|
|
|
|
|
service.Verify(s => s.StartSession(It.Is<ServiceConfiguration>(c => c.SessionId == session2Id)), Times.Once);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Never);
|
2019-07-04 09:12:28 +02:00
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Never);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
Assert.IsTrue(start1 == 1);
|
|
|
|
|
Assert.IsTrue(stop1 == 2);
|
|
|
|
|
Assert.IsTrue(start2 == 3);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-11 11:45:05 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Repeat_MustEstablishConnectionIfNotConnected()
|
|
|
|
|
{
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
service.Reset();
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true).Callback(() => service.SetupGet(s => s.IsConnected).Returns(true));
|
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
2019-06-11 11:45:05 +02:00
|
|
|
|
|
|
|
|
|
var result = sut.Repeat();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.Connect(It.IsAny<Guid?>(), It.IsAny<bool>()), Times.Once);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Never);
|
2019-06-11 11:45:05 +02:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-23 13:53:10 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Repeat_MustNotEstablishConnectionWithIgnoreSet()
|
|
|
|
|
{
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
context.Next.Settings.Service.IgnoreService = true;
|
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Mandatory;
|
|
|
|
|
|
|
|
|
|
service.Reset();
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true).Callback(() => service.SetupGet(s => s.IsConnected).Returns(true));
|
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
|
|
|
|
|
|
|
|
|
var result = sut.Repeat();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.Connect(It.IsAny<Guid?>(), It.IsAny<bool>()), Times.Never);
|
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Never);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Repeat_MustStopSessionAndCloseConnectionWithIgnoreSet()
|
|
|
|
|
{
|
|
|
|
|
var connected = true;
|
|
|
|
|
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
context.Next.Settings.Service.IgnoreService = true;
|
|
|
|
|
context.Next.Settings.Service.Policy = ServicePolicy.Mandatory;
|
|
|
|
|
|
|
|
|
|
service.Reset();
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(() => connected);
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
|
|
|
|
service.Setup(s => s.Disconnect()).Returns(true).Callback(() => connected = false);
|
|
|
|
|
|
|
|
|
|
var result = sut.Repeat();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.Connect(It.IsAny<Guid?>(), It.IsAny<bool>()), Times.Never);
|
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Never);
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Once);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-21 15:28:59 +01:00
|
|
|
|
[TestMethod]
|
2019-06-06 15:44:03 +02:00
|
|
|
|
public void Repeat_MustFailIfCurrentSessionWasNotStoppedSuccessfully()
|
2018-03-21 15:28:59 +01:00
|
|
|
|
{
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(false));
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
var result = sut.Repeat();
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Once);
|
2019-06-11 09:53:33 +02:00
|
|
|
|
service.Verify(s => s.StartSession(It.IsAny<ServiceConfiguration>()), Times.Once);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Never);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
2018-03-21 15:28:59 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-06-18 10:18:56 +02:00
|
|
|
|
public void Repeat_MustFailIfSessionNotStoppedWithinTimeout()
|
2018-03-21 15:28:59 +01:00
|
|
|
|
{
|
2019-06-18 10:18:56 +02:00
|
|
|
|
const int TIMEOUT = 50;
|
|
|
|
|
|
|
|
|
|
var after = default(DateTime);
|
|
|
|
|
var before = default(DateTime);
|
|
|
|
|
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true));
|
2019-12-10 14:22:18 +01:00
|
|
|
|
sut = new ServiceOperation(logger.Object, runtimeHost.Object, service.Object, context, TIMEOUT, userInfo.Object);
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
PerformNormally();
|
2018-03-21 15:28:59 +01:00
|
|
|
|
|
2019-06-18 10:18:56 +02:00
|
|
|
|
before = DateTime.Now;
|
|
|
|
|
var result = sut.Repeat();
|
|
|
|
|
after = DateTime.Now;
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Once);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Never);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
Assert.IsTrue(after - before >= new TimeSpan(0, 0, 0, 0, TIMEOUT));
|
2018-03-21 15:28:59 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-01-25 09:50:46 +01:00
|
|
|
|
[TestMethod]
|
2019-12-10 14:22:18 +01:00
|
|
|
|
public void Repeat_MustNotStopSessionIfNoSessionRunning()
|
2018-01-25 09:50:46 +01:00
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
var result = sut.Repeat();
|
2018-01-25 09:50:46 +01:00
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Never);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
2019-06-18 10:18:56 +02:00
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
2018-01-25 09:50:46 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-01-23 15:33:54 +01:00
|
|
|
|
[TestMethod]
|
2019-12-10 14:22:18 +01:00
|
|
|
|
public void Revert_MustDisconnect()
|
2018-01-23 15:33:54 +01:00
|
|
|
|
{
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.Setup(s => s.Disconnect()).Returns(true);
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
2019-07-04 09:12:28 +02:00
|
|
|
|
service.Setup(s => s.RunSystemConfigurationUpdate()).Returns(new CommunicationResult(true));
|
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
PerformNormally();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
var result = sut.Revert();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustHandleCommunicationFailureWhenStoppingSession()
|
|
|
|
|
{
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(false));
|
2019-07-04 09:12:28 +02:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Once);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
2019-07-04 09:12:28 +02:00
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Never);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustHandleCommunicationFailureWhenInitiatingSystemConfigurationUpdate()
|
|
|
|
|
{
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
|
|
|
|
service.Setup(s => s.RunSystemConfigurationUpdate()).Returns(new CommunicationResult(false));
|
|
|
|
|
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Once);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Once);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-11 11:45:05 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustFailIfSessionStopUnsuccessful()
|
|
|
|
|
{
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true));
|
2019-06-11 11:45:05 +02:00
|
|
|
|
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
2019-07-04 09:12:28 +02:00
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Never);
|
|
|
|
|
|
2019-06-11 11:45:05 +02:00
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustFailIfSessionNotStoppedWithinTimeout()
|
|
|
|
|
{
|
|
|
|
|
const int TIMEOUT = 50;
|
|
|
|
|
|
|
|
|
|
var after = default(DateTime);
|
|
|
|
|
var before = default(DateTime);
|
|
|
|
|
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true));
|
2019-12-10 14:22:18 +01:00
|
|
|
|
sut = new ServiceOperation(logger.Object, runtimeHost.Object, service.Object, context, TIMEOUT, userInfo.Object);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
before = DateTime.Now;
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
after = DateTime.Now;
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Once);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
2019-07-04 09:12:28 +02:00
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Never);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Failed, result);
|
|
|
|
|
Assert.IsTrue(after - before >= new TimeSpan(0, 0, 0, 0, TIMEOUT));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustNotStopSessionWhenNotConnected()
|
|
|
|
|
{
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Never);
|
2019-12-10 14:22:18 +01:00
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-18 10:18:56 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustNotStopSessionIfNoSessionRunning()
|
|
|
|
|
{
|
2019-12-10 14:22:18 +01:00
|
|
|
|
context.Current = null;
|
|
|
|
|
context.Next = null;
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.Disconnect()).Returns(true);
|
|
|
|
|
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.IsAny<Guid>()), Times.Never);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustNotDisconnnectIfNotConnected()
|
|
|
|
|
{
|
|
|
|
|
var result = sut.Revert();
|
2018-01-24 12:34:32 +01:00
|
|
|
|
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Never);
|
2019-06-06 15:44:03 +02:00
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-10 14:22:18 +01:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustStopSessionIfConnected()
|
|
|
|
|
{
|
|
|
|
|
context.Next.SessionId = Guid.NewGuid();
|
|
|
|
|
service.Setup(s => s.Disconnect()).Returns(true);
|
|
|
|
|
service.Setup(s => s.StopSession(It.IsAny<Guid>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
|
|
|
|
service.Setup(s => s.RunSystemConfigurationUpdate()).Returns(new CommunicationResult(true));
|
|
|
|
|
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.Is<Guid>(id => id == context.Next.SessionId)), Times.Once);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
|
|
|
|
service.Verify(s => s.RunSystemConfigurationUpdate(), Times.Once);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Revert_MustStopSessionIfNewSessionNotCompletelyStarted()
|
|
|
|
|
{
|
|
|
|
|
var sessionId = Guid.NewGuid();
|
|
|
|
|
|
|
|
|
|
context.Current.SessionId = Guid.NewGuid();
|
|
|
|
|
context.Next.SessionId = sessionId;
|
|
|
|
|
|
|
|
|
|
PerformNormally();
|
|
|
|
|
|
|
|
|
|
context.Current.SessionId = default(Guid);
|
|
|
|
|
context.Next.SessionId = default(Guid);
|
|
|
|
|
service.Setup(s => s.StopSession(It.Is<Guid>(id => id == sessionId))).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
|
|
|
|
service.Setup(s => s.RunSystemConfigurationUpdate()).Returns(new CommunicationResult(true));
|
|
|
|
|
service.Setup(s => s.Disconnect()).Returns(true);
|
|
|
|
|
|
|
|
|
|
var result = sut.Revert();
|
|
|
|
|
|
|
|
|
|
service.Verify(s => s.StopSession(It.Is<Guid>(id => id == sessionId)), Times.Once);
|
|
|
|
|
service.Verify(s => s.StopSession(It.Is<Guid>(id => id == default(Guid))), Times.Never);
|
|
|
|
|
service.Verify(s => s.Disconnect(), Times.Once);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(OperationResult.Success, result);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
private void PerformNormally()
|
|
|
|
|
{
|
|
|
|
|
service.SetupGet(s => s.IsConnected).Returns(true);
|
|
|
|
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
2019-06-18 10:18:56 +02:00
|
|
|
|
service.Setup(s => s.StartSession(It.IsAny<ServiceConfiguration>())).Returns(new CommunicationResult(true)).Callback(() => serviceEvent.Set());
|
2019-06-06 15:44:03 +02:00
|
|
|
|
|
|
|
|
|
sut.Perform();
|
2018-01-23 15:33:54 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|