2019-06-27 08:32:37 +02:00
|
|
|
|
/*
|
2024-03-05 18:37:42 +01:00
|
|
|
|
* Copyright (c) 2024 ETH Zürich, IT Services
|
2019-06-27 08:32:37 +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 System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
|
|
|
|
using Moq;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Lockdown.Contracts;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2019-06-27 08:32:37 +02:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Lockdown.UnitTests
|
|
|
|
|
{
|
|
|
|
|
[TestClass]
|
|
|
|
|
public class AutoRestoreMechanismTests
|
|
|
|
|
{
|
|
|
|
|
private Mock<IFeatureConfigurationBackup> backup;
|
|
|
|
|
private Mock<ILogger> logger;
|
2019-07-03 12:27:02 +02:00
|
|
|
|
private Mock<ISystemConfigurationUpdate> systemConfigurationUpdate;
|
2019-06-27 08:32:37 +02:00
|
|
|
|
private AutoRestoreMechanism sut;
|
|
|
|
|
|
|
|
|
|
[TestInitialize]
|
|
|
|
|
public void Initialize()
|
|
|
|
|
{
|
|
|
|
|
backup = new Mock<IFeatureConfigurationBackup>();
|
|
|
|
|
logger = new Mock<ILogger>();
|
2019-07-03 12:27:02 +02:00
|
|
|
|
systemConfigurationUpdate = new Mock<ISystemConfigurationUpdate>();
|
2019-06-27 08:32:37 +02:00
|
|
|
|
|
2019-07-03 12:27:02 +02:00
|
|
|
|
sut = new AutoRestoreMechanism(backup.Object, logger.Object, systemConfigurationUpdate.Object, 0);
|
2019-06-27 08:32:37 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustExecuteAsynchronously()
|
|
|
|
|
{
|
|
|
|
|
var sync = new AutoResetEvent(false);
|
|
|
|
|
var threadId = Thread.CurrentThread.ManagedThreadId;
|
|
|
|
|
|
|
|
|
|
backup.Setup(b => b.GetAllConfigurations()).Callback(() => { threadId = Thread.CurrentThread.ManagedThreadId; sync.Set(); });
|
|
|
|
|
|
|
|
|
|
sut.Start();
|
|
|
|
|
sync.WaitOne();
|
|
|
|
|
sut.Stop();
|
|
|
|
|
|
|
|
|
|
Assert.AreNotEqual(Thread.CurrentThread.ManagedThreadId, threadId);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-27 10:47:41 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustNotStartMultipleTimes()
|
|
|
|
|
{
|
|
|
|
|
var counter = 0;
|
|
|
|
|
var list = new List<IFeatureConfiguration>();
|
|
|
|
|
var sync = new AutoResetEvent(false);
|
|
|
|
|
|
|
|
|
|
backup.Setup(b => b.GetAllConfigurations()).Returns(() => { counter++; Thread.Sleep(50); sync.Set(); return list; });
|
|
|
|
|
|
|
|
|
|
sut.Start();
|
|
|
|
|
sut.Start();
|
|
|
|
|
sut.Start();
|
|
|
|
|
sut.Start();
|
|
|
|
|
sut.Start();
|
|
|
|
|
sut.Start();
|
|
|
|
|
sut.Start();
|
|
|
|
|
sync.WaitOne();
|
|
|
|
|
sut.Stop();
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(1, counter);
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-27 08:32:37 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustNotTerminateUntilAllChangesReverted()
|
|
|
|
|
{
|
|
|
|
|
var configuration = new Mock<IFeatureConfiguration>();
|
|
|
|
|
var counter = 0;
|
|
|
|
|
var limit = new Random().Next(5, 50);
|
|
|
|
|
var list = new List<IFeatureConfiguration> { configuration.Object };
|
|
|
|
|
var sync = new AutoResetEvent(false);
|
|
|
|
|
|
2019-07-03 12:27:02 +02:00
|
|
|
|
backup.Setup(b => b.GetAllConfigurations()).Returns(() => new List<IFeatureConfiguration>(list)).Callback(() => counter++);
|
|
|
|
|
backup.Setup(b => b.Delete(It.IsAny<IFeatureConfiguration>())).Callback(() => list.Clear());
|
|
|
|
|
configuration.Setup(c => c.Restore()).Returns(() => counter >= limit);
|
|
|
|
|
systemConfigurationUpdate.Setup(u => u.ExecuteAsync()).Callback(() => sync.Set());
|
2019-06-27 08:32:37 +02:00
|
|
|
|
|
|
|
|
|
sut.Start();
|
|
|
|
|
sync.WaitOne();
|
|
|
|
|
sut.Stop();
|
|
|
|
|
|
2019-07-05 12:28:42 +02:00
|
|
|
|
backup.Verify(b => b.GetAllConfigurations(), Times.Exactly(limit));
|
2019-06-27 08:32:37 +02:00
|
|
|
|
backup.Verify(b => b.Delete(It.Is<IFeatureConfiguration>(c => c == configuration.Object)), Times.Once);
|
|
|
|
|
configuration.Verify(c => c.Restore(), Times.Exactly(limit));
|
2019-07-03 12:27:02 +02:00
|
|
|
|
systemConfigurationUpdate.Verify(u => u.Execute(), Times.Never);
|
|
|
|
|
systemConfigurationUpdate.Verify(u => u.ExecuteAsync(), Times.Once);
|
2019-06-27 08:32:37 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustRespectTimeout()
|
|
|
|
|
{
|
|
|
|
|
const int TIMEOUT = 50;
|
|
|
|
|
|
|
|
|
|
var after = default(DateTime);
|
|
|
|
|
var before = default(DateTime);
|
|
|
|
|
var configuration = new Mock<IFeatureConfiguration>();
|
|
|
|
|
var counter = 0;
|
|
|
|
|
var list = new List<IFeatureConfiguration> { configuration.Object };
|
|
|
|
|
var sync = new AutoResetEvent(false);
|
|
|
|
|
|
2019-07-03 12:27:02 +02:00
|
|
|
|
sut = new AutoRestoreMechanism(backup.Object, logger.Object, systemConfigurationUpdate.Object, TIMEOUT);
|
2019-06-27 08:32:37 +02:00
|
|
|
|
|
|
|
|
|
backup.Setup(b => b.GetAllConfigurations()).Returns(list).Callback(() =>
|
|
|
|
|
{
|
|
|
|
|
switch (++counter)
|
|
|
|
|
{
|
|
|
|
|
case 1:
|
|
|
|
|
before = DateTime.Now;
|
|
|
|
|
break;
|
|
|
|
|
case 2:
|
|
|
|
|
after = DateTime.Now;
|
|
|
|
|
list.Clear();
|
|
|
|
|
sync.Set();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
sut.Start();
|
|
|
|
|
sync.WaitOne();
|
|
|
|
|
sut.Stop();
|
|
|
|
|
|
|
|
|
|
Assert.IsTrue(after - before >= new TimeSpan(0, 0, 0, 0, TIMEOUT));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustStop()
|
|
|
|
|
{
|
|
|
|
|
var configuration = new Mock<IFeatureConfiguration>();
|
|
|
|
|
var counter = 0;
|
|
|
|
|
var list = new List<IFeatureConfiguration> { configuration.Object };
|
|
|
|
|
|
|
|
|
|
backup.Setup(b => b.GetAllConfigurations()).Returns(list).Callback(() => counter++);
|
|
|
|
|
|
|
|
|
|
sut.Start();
|
|
|
|
|
Thread.Sleep(25);
|
|
|
|
|
sut.Stop();
|
|
|
|
|
|
2019-07-10 08:20:07 +02:00
|
|
|
|
backup.Verify(b => b.GetAllConfigurations(), Times.Between(counter, counter + 1, Range.Inclusive));
|
2019-06-27 08:32:37 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-07-03 12:27:02 +02:00
|
|
|
|
[ExpectedException(typeof(ArgumentException))]
|
2019-06-27 08:32:37 +02:00
|
|
|
|
public void MustValidateTimeout()
|
|
|
|
|
{
|
2019-07-03 12:27:02 +02:00
|
|
|
|
new AutoRestoreMechanism(backup.Object, logger.Object, systemConfigurationUpdate.Object, new Random().Next(int.MinValue, -1));
|
2019-06-27 08:32:37 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|