SEBWIN-296: Fixed unit tests for configuration operation in runtime.
This commit is contained in:
parent
875bb57c95
commit
be3fbf12c6
1 changed files with 386 additions and 333 deletions
|
@ -12,6 +12,7 @@ using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||||
using Moq;
|
using Moq;
|
||||||
using SafeExamBrowser.Contracts.Communication.Data;
|
using SafeExamBrowser.Contracts.Communication.Data;
|
||||||
using SafeExamBrowser.Contracts.Configuration;
|
using SafeExamBrowser.Contracts.Configuration;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration.Cryptography;
|
||||||
using SafeExamBrowser.Contracts.Configuration.Settings;
|
using SafeExamBrowser.Contracts.Configuration.Settings;
|
||||||
using SafeExamBrowser.Contracts.Core.OperationModel;
|
using SafeExamBrowser.Contracts.Core.OperationModel;
|
||||||
using SafeExamBrowser.Contracts.Logging;
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
@ -24,11 +25,12 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
public class ConfigurationOperationTests
|
public class ConfigurationOperationTests
|
||||||
{
|
{
|
||||||
private AppConfig appConfig;
|
private AppConfig appConfig;
|
||||||
|
private Mock<IHashAlgorithm> hashAlgorithm;
|
||||||
private Mock<ILogger> logger;
|
private Mock<ILogger> logger;
|
||||||
private Mock<IConfigurationRepository> repository;
|
private Mock<IConfigurationRepository> repository;
|
||||||
private Mock<ISessionConfiguration> session;
|
private Mock<ISessionConfiguration> currentSession;
|
||||||
|
private Mock<ISessionConfiguration> nextSession;
|
||||||
private SessionContext sessionContext;
|
private SessionContext sessionContext;
|
||||||
private Settings settings;
|
|
||||||
|
|
||||||
private ConfigurationOperation sut;
|
private ConfigurationOperation sut;
|
||||||
|
|
||||||
|
@ -36,388 +38,439 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
public void Initialize()
|
public void Initialize()
|
||||||
{
|
{
|
||||||
appConfig = new AppConfig();
|
appConfig = new AppConfig();
|
||||||
|
hashAlgorithm = new Mock<IHashAlgorithm>();
|
||||||
logger = new Mock<ILogger>();
|
logger = new Mock<ILogger>();
|
||||||
repository = new Mock<IConfigurationRepository>();
|
repository = new Mock<IConfigurationRepository>();
|
||||||
session = new Mock<ISessionConfiguration>();
|
currentSession = new Mock<ISessionConfiguration>();
|
||||||
|
nextSession = new Mock<ISessionConfiguration>();
|
||||||
sessionContext = new SessionContext();
|
sessionContext = new SessionContext();
|
||||||
settings = new Settings();
|
|
||||||
|
|
||||||
appConfig.AppDataFolder = @"C:\Not\Really\AppData";
|
appConfig.AppDataFolder = @"C:\Not\Really\AppData";
|
||||||
appConfig.DefaultSettingsFileName = "SettingsDummy.txt";
|
appConfig.DefaultSettingsFileName = "SettingsDummy.txt";
|
||||||
appConfig.ProgramDataFolder = @"C:\Not\Really\ProgramData";
|
appConfig.ProgramDataFolder = @"C:\Not\Really\ProgramData";
|
||||||
session.SetupGet(s => s.AppConfig).Returns(appConfig);
|
currentSession.SetupGet(s => s.AppConfig).Returns(appConfig);
|
||||||
session.SetupGet(s => s.Settings).Returns(settings);
|
nextSession.SetupGet(s => s.AppConfig).Returns(appConfig);
|
||||||
sessionContext.Next = session.Object;
|
sessionContext.Current = currentSession.Object;
|
||||||
|
sessionContext.Next = nextSession.Object;
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void TODO()
|
public void MustUseCommandLineArgumentAs1stPrio()
|
||||||
{
|
{
|
||||||
Assert.Fail();
|
var settings = new Settings { ConfigurationMode = ConfigurationMode.Exam };
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
var location = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
||||||
|
|
||||||
|
appConfig.AppDataFolder = location;
|
||||||
|
appConfig.ProgramDataFolder = location;
|
||||||
|
appConfig.DefaultSettingsFileName = "SettingsDummy.txt";
|
||||||
|
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
var resource = new Uri(url);
|
||||||
|
|
||||||
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.Once);
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
//[TestMethod]
|
[TestMethod]
|
||||||
//public void MustUseCommandLineArgumentAs1stPrio()
|
public void MustUseProgramDataAs2ndPrio()
|
||||||
//{
|
{
|
||||||
// var settings = default(Settings);
|
var location = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
var settings = default(Settings);
|
||||||
// var location = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
|
||||||
|
|
||||||
// appConfig.ProgramDataFolder = location;
|
appConfig.ProgramDataFolder = location;
|
||||||
// appConfig.AppDataFolder = location;
|
appConfig.AppDataFolder = $@"{location}\WRONG";
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// var resource = new Uri(url);
|
var result = sut.Perform();
|
||||||
|
var resource = new Uri(Path.Combine(location, "SettingsDummy.txt"));
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null), Times.Once);
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.Once);
|
||||||
//}
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
}
|
||||||
|
|
||||||
//[TestMethod]
|
[TestMethod]
|
||||||
//public void MustUseProgramDataAs2ndPrio()
|
public void MustUseAppDataAs3rdPrio()
|
||||||
//{
|
{
|
||||||
// var location = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
var location = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
||||||
|
var settings = default(Settings);
|
||||||
|
|
||||||
// appConfig.ProgramDataFolder = location;
|
appConfig.AppDataFolder = location;
|
||||||
// appConfig.AppDataFolder = $@"{location}\WRONG";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// var resource = new Uri(Path.Combine(location, "SettingsDummy.txt"));
|
var result = sut.Perform();
|
||||||
|
var resource = new Uri(Path.Combine(location, "SettingsDummy.txt"));
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null), Times.Once);
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.Once);
|
||||||
//}
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
}
|
||||||
|
|
||||||
//[TestMethod]
|
[TestMethod]
|
||||||
//public void MustUseAppDataAs3rdPrio()
|
public void MustFallbackToDefaultsAsLastPrio()
|
||||||
//{
|
{
|
||||||
// var location = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
var actualSettings = default(Settings);
|
||||||
|
var defaultSettings = new Settings();
|
||||||
|
|
||||||
// appConfig.AppDataFolder = location;
|
repository.Setup(r => r.LoadDefaultSettings()).Returns(defaultSettings);
|
||||||
|
nextSession.SetupSet<Settings>(s => s.Settings = It.IsAny<Settings>()).Callback(s => actualSettings = s);
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
var result = sut.Perform();
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// var resource = new Uri(Path.Combine(location, "SettingsDummy.txt"));
|
repository.Verify(r => r.LoadDefaultSettings(), Times.Once);
|
||||||
|
nextSession.VerifySet(s => s.Settings = defaultSettings);
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null), Times.Once);
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
//}
|
Assert.AreSame(defaultSettings, actualSettings);
|
||||||
|
}
|
||||||
|
|
||||||
//[TestMethod]
|
[TestMethod]
|
||||||
//public void MustFallbackToDefaultsAsLastPrio()
|
public void MustAbortIfWishedByUser()
|
||||||
//{
|
{
|
||||||
// var actualSettings = default(Settings);
|
var settings = new Settings();
|
||||||
// var defaultSettings = new Settings();
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
// repository.Setup(r => r.LoadDefaultSettings()).Returns(defaultSettings);
|
sessionContext.Current = null;
|
||||||
// session.SetupSet<Settings>(s => s.Settings = It.IsAny<Settings>()).Callback(s => actualSettings = s);
|
settings.ConfigurationMode = ConfigurationMode.ConfigureClient;
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
repository.Setup(r => r.ConfigureClientWith(It.IsAny<Uri>(), It.IsAny<PasswordParameters>())).Returns(SaveStatus.Success);
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
// sut.Perform();
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is ConfigurationCompletedEventArgs c)
|
||||||
|
{
|
||||||
|
c.AbortStartup = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// repository.Verify(r => r.LoadDefaultSettings(), Times.Once);
|
var result = sut.Perform();
|
||||||
// session.VerifySet(s => s.Settings = defaultSettings);
|
|
||||||
|
|
||||||
// Assert.AreSame(defaultSettings, actualSettings);
|
Assert.AreEqual(OperationResult.Aborted, result);
|
||||||
//}
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustNotAbortIfNotWishedByUser()
|
||||||
|
{
|
||||||
|
var settings = new Settings();
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
settings.ConfigurationMode = ConfigurationMode.ConfigureClient;
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
repository.Setup(r => r.ConfigureClientWith(It.IsAny<Uri>(), It.IsAny<PasswordParameters>())).Returns(SaveStatus.Success);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is ConfigurationCompletedEventArgs c)
|
||||||
|
{
|
||||||
|
c.AbortStartup = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
//[TestMethod]
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
//public void MustAbortIfWishedByUser()
|
}
|
||||||
//{
|
|
||||||
// appConfig.ProgramDataFolder = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
[TestMethod]
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
public void MustNotAllowToAbortIfNotInConfigureClientMode()
|
||||||
|
{
|
||||||
|
var settings = new Settings();
|
||||||
|
|
||||||
|
settings.ConfigurationMode = ConfigurationMode.Exam;
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is ConfigurationCompletedEventArgs c)
|
||||||
|
{
|
||||||
|
Assert.Fail();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustNotFailWithoutCommandLineArgs()
|
||||||
|
{
|
||||||
|
var actualSettings = default(Settings);
|
||||||
|
var defaultSettings = new Settings();
|
||||||
|
var result = OperationResult.Failed;
|
||||||
|
|
||||||
|
repository.Setup(r => r.LoadDefaultSettings()).Returns(defaultSettings);
|
||||||
|
nextSession.SetupSet<Settings>(s => s.Settings = It.IsAny<Settings>()).Callback(s => actualSettings = s);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
result = sut.Perform();
|
||||||
|
|
||||||
|
repository.Verify(r => r.LoadDefaultSettings(), Times.Once);
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
Assert.AreSame(defaultSettings, actualSettings);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new string[] { }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
result = sut.Perform();
|
||||||
|
|
||||||
|
repository.Verify(r => r.LoadDefaultSettings(), Times.Exactly(2));
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
Assert.AreSame(defaultSettings, actualSettings);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustNotFailWithInvalidUri()
|
||||||
|
{
|
||||||
|
var uri = @"an/invalid\uri.'*%yolo/()你好";
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", uri }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustOnlyAllowToEnterAdminPasswordFiveTimes()
|
||||||
|
{
|
||||||
|
var count = 0;
|
||||||
|
var localSettings = new Settings { AdminPasswordHash = "1234" };
|
||||||
|
var settings = new Settings { AdminPasswordHash = "9876", ConfigurationMode = ConfigurationMode.ConfigureClient };
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
appConfig.AppDataFolder = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
||||||
|
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.Is<Uri>(u => u.LocalPath.Contains("SettingsDummy")), out localSettings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
nextSession.SetupGet(s => s.Settings).Returns(settings);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is PasswordRequiredEventArgs p && p.Purpose == PasswordRequestPurpose.LocalAdministrator)
|
||||||
|
{
|
||||||
|
count++;
|
||||||
|
p.Success = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
Assert.AreEqual(5, count);
|
||||||
|
Assert.AreEqual(OperationResult.Failed, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustOnlyAllowToEnterSettingsPasswordFiveTimes()
|
||||||
|
{
|
||||||
|
var count = 0;
|
||||||
|
var settings = default(Settings);
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.PasswordNeeded);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is PasswordRequiredEventArgs p && p.Purpose == PasswordRequestPurpose.Settings)
|
||||||
|
{
|
||||||
|
count++;
|
||||||
|
p.Success = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>()), Times.Exactly(6));
|
||||||
|
|
||||||
|
Assert.AreEqual(5, count);
|
||||||
|
Assert.AreEqual(OperationResult.Failed, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustSucceedIfAdminPasswordCorrect()
|
||||||
|
{
|
||||||
|
var password = "test";
|
||||||
|
var currentSettings = new Settings { AdminPasswordHash = "1234", ConfigurationMode = ConfigurationMode.ConfigureClient };
|
||||||
|
var nextSettings = new Settings { AdminPasswordHash = "9876", ConfigurationMode = ConfigurationMode.ConfigureClient };
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
appConfig.AppDataFolder = Path.Combine(Path.GetDirectoryName(GetType().Assembly.Location), nameof(Operations));
|
||||||
|
nextSession.SetupGet(s => s.Settings).Returns(nextSettings);
|
||||||
|
|
||||||
|
hashAlgorithm.Setup(h => h.GenerateHashFor(It.Is<string>(p => p == password))).Returns(currentSettings.AdminPasswordHash);
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out currentSettings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.Is<Uri>(u => u.AbsoluteUri == url), out nextSettings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
repository.Setup(r => r.ConfigureClientWith(It.IsAny<Uri>(), It.IsAny<PasswordParameters>())).Returns(SaveStatus.Success);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is PasswordRequiredEventArgs p && p.Purpose == PasswordRequestPurpose.LocalAdministrator)
|
||||||
|
{
|
||||||
|
p.Password = password;
|
||||||
|
p.Success = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
repository.Verify(r => r.ConfigureClientWith(It.IsAny<Uri>(), It.IsAny<PasswordParameters>()), Times.Once);
|
||||||
|
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustSucceedIfSettingsPasswordCorrect()
|
||||||
|
{
|
||||||
|
var password = "test";
|
||||||
|
var settings = new Settings { ConfigurationMode = ConfigurationMode.Exam };
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.PasswordNeeded);
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.Is<PasswordParameters>(p => p.Password == password))).Returns(LoadStatus.Success);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is PasswordRequiredEventArgs p)
|
||||||
|
{
|
||||||
|
p.Password = password;
|
||||||
|
p.Success = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.Is<PasswordParameters>(p => p.Password == password)), Times.AtLeastOnce);
|
||||||
|
|
||||||
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustAbortAskingForAdminPasswordIfDecidedByUser()
|
||||||
|
{
|
||||||
|
var settings = default(Settings);
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.PasswordNeeded);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is PasswordRequiredEventArgs p)
|
||||||
|
{
|
||||||
|
p.Success = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
Assert.AreEqual(OperationResult.Aborted, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustAbortAskingForSettingsPasswordIfDecidedByUser()
|
||||||
|
{
|
||||||
|
var settings = default(Settings);
|
||||||
|
var url = @"http://www.safeexambrowser.org/whatever.seb";
|
||||||
|
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.PasswordNeeded);
|
||||||
|
|
||||||
|
sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
sut.ActionRequired += args =>
|
||||||
|
{
|
||||||
|
if (args is PasswordRequiredEventArgs p)
|
||||||
|
{
|
||||||
|
p.Success = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
Assert.AreEqual(OperationResult.Aborted, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustReconfigureForExamWithCorrectUri()
|
||||||
|
{
|
||||||
|
var currentSettings = new Settings();
|
||||||
|
var location = Path.GetDirectoryName(GetType().Assembly.Location);
|
||||||
|
var resource = new Uri(Path.Combine(location, nameof(Operations), "SettingsDummy.txt"));
|
||||||
|
var settings = new Settings { ConfigurationMode = ConfigurationMode.Exam };
|
||||||
|
|
||||||
|
currentSession.SetupGet(s => s.Settings).Returns(currentSettings);
|
||||||
|
sessionContext.ReconfigurationFilePath = resource.LocalPath;
|
||||||
|
repository.Setup(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
var result = sut.Repeat();
|
||||||
// if (args is ConfigurationCompletedEventArgs c)
|
|
||||||
// {
|
|
||||||
// c.AbortStartup = true;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// var result = sut.Perform();
|
nextSession.VerifySet(s => s.Settings = settings, Times.Once);
|
||||||
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.AtLeastOnce);
|
||||||
|
repository.Verify(r => r.ConfigureClientWith(It.Is<Uri>(u => u.Equals(resource)), It.IsAny<PasswordParameters>()), Times.Never);
|
||||||
|
|
||||||
// Assert.AreEqual(OperationResult.Aborted, result);
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
//}
|
}
|
||||||
|
|
||||||
//[TestMethod]
|
[TestMethod]
|
||||||
//public void MustNotAbortIfNotWishedByUser()
|
public void MustReconfigureForClientConfigurationWithCorrectUri()
|
||||||
//{
|
{
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
var currentSettings = new Settings();
|
||||||
|
var location = Path.GetDirectoryName(GetType().Assembly.Location);
|
||||||
|
var resource = new Uri(Path.Combine(location, nameof(Operations), "SettingsDummy.txt"));
|
||||||
|
var settings = new Settings { ConfigurationMode = ConfigurationMode.ConfigureClient };
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
currentSession.SetupGet(s => s.Settings).Returns(currentSettings);
|
||||||
// sut.ActionRequired += args =>
|
sessionContext.ReconfigurationFilePath = resource.LocalPath;
|
||||||
// {
|
repository.Setup(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
// if (args is ConfigurationCompletedEventArgs c)
|
repository.Setup(r => r.ConfigureClientWith(It.Is<Uri>(u => u.Equals(resource)), It.IsAny<PasswordParameters>())).Returns(SaveStatus.Success);
|
||||||
// {
|
|
||||||
// c.AbortStartup = false;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// var result = sut.Perform();
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
|
|
||||||
// Assert.AreEqual(OperationResult.Success, result);
|
var result = sut.Repeat();
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
nextSession.VerifySet(s => s.Settings = settings, Times.Once);
|
||||||
//public void MustNotAllowToAbortIfNotInConfigureClientMode()
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.AtLeastOnce);
|
||||||
//{
|
repository.Verify(r => r.ConfigureClientWith(It.Is<Uri>(u => u.Equals(resource)), It.IsAny<PasswordParameters>()), Times.Once);
|
||||||
// settings.ConfigurationMode = ConfigurationMode.Exam;
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
Assert.AreEqual(OperationResult.Success, result);
|
||||||
// sut.ActionRequired += args =>
|
}
|
||||||
// {
|
|
||||||
// if (args is ConfigurationCompletedEventArgs c)
|
|
||||||
// {
|
|
||||||
// Assert.Fail();
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// sut.Perform();
|
[TestMethod]
|
||||||
//}
|
public void MustFailToReconfigureWithInvalidUri()
|
||||||
|
{
|
||||||
|
var resource = new Uri("file:///C:/does/not/exist.txt");
|
||||||
|
var settings = default(Settings);
|
||||||
|
|
||||||
//[TestMethod]
|
sessionContext.ReconfigurationFilePath = null;
|
||||||
//public void MustNotFailWithoutCommandLineArgs()
|
repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, It.IsAny<PasswordParameters>())).Returns(LoadStatus.Success);
|
||||||
//{
|
|
||||||
// var actualSettings = default(Settings);
|
|
||||||
// var defaultSettings = new Settings();
|
|
||||||
|
|
||||||
// repository.Setup(r => r.LoadDefaultSettings()).Returns(defaultSettings);
|
|
||||||
// session.SetupSet<Settings>(s => s.Settings = It.IsAny<Settings>()).Callback(s => actualSettings = s);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.LoadDefaultSettings(), Times.Once);
|
|
||||||
|
|
||||||
// Assert.AreSame(defaultSettings, actualSettings);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new string[] { }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.LoadDefaultSettings(), Times.Exactly(2));
|
|
||||||
|
|
||||||
// Assert.AreSame(defaultSettings, actualSettings);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustNotFailWithInvalidUri()
|
|
||||||
//{
|
|
||||||
// var uri = @"an/invalid\uri.'*%yolo/()你好";
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", uri }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.Perform();
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustOnlyAllowToEnterAdminPasswordFiveTimes()
|
|
||||||
//{
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Success = true;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null), Times.Exactly(5));
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustOnlyAllowToEnterSettingsPasswordFiveTimes()
|
|
||||||
//{
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Success = true;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null), Times.Exactly(5));
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustSucceedIfAdminPasswordCorrect()
|
|
||||||
//{
|
|
||||||
// var password = "test";
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, password)).Returns(LoadStatus.Success);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Password = password;
|
|
||||||
// p.Success = true;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null), Times.Once);
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, password), Times.Once);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustSucceedIfSettingsPasswordCorrect()
|
|
||||||
//{
|
|
||||||
// var password = "test";
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, password)).Returns(LoadStatus.Success);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Password = password;
|
|
||||||
// p.Success = true;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null), Times.Once);
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, password), Times.Once);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustAbortAskingForAdminPasswordIfDecidedByUser()
|
|
||||||
//{
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Success = false;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// var result = sut.Perform();
|
|
||||||
|
|
||||||
// Assert.AreEqual(OperationResult.Aborted, result);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustAbortAskingForSettingsPasswordIfDecidedByUser()
|
|
||||||
//{
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Success = false;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// var result = sut.Perform();
|
|
||||||
|
|
||||||
// Assert.AreEqual(OperationResult.Aborted, result);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustAllowEnteringBothPasswords()
|
|
||||||
//{
|
|
||||||
// var adminPassword = "xyz";
|
|
||||||
// var settingsPassword = "abc";
|
|
||||||
// var url = @"http://www.safeexambrowser.org/whatever.seb";
|
|
||||||
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.PasswordNeeded);
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, settingsPassword)).Returns(LoadStatus.Success);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(new[] { "blubb.exe", url }, repository.Object, logger.Object, sessionContext);
|
|
||||||
// sut.ActionRequired += args =>
|
|
||||||
// {
|
|
||||||
// if (args is PasswordRequiredEventArgs p)
|
|
||||||
// {
|
|
||||||
// p.Password = p.Purpose == PasswordRequestPurpose.Administrator ? adminPassword : settingsPassword;
|
|
||||||
// p.Success = true;
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
|
|
||||||
// sut.Perform();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null), Times.Once);
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, settingsPassword), Times.Once);
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, settingsPassword), Times.Once);
|
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
sut = new ConfigurationOperation(null, repository.Object, hashAlgorithm.Object, logger.Object, sessionContext);
|
||||||
//public void MustReconfigureSuccessfullyWithCorrectUri()
|
|
||||||
//{
|
|
||||||
// var location = Path.GetDirectoryName(GetType().Assembly.Location);
|
|
||||||
// var resource = new Uri(Path.Combine(location, nameof(Operations), "SettingsDummy.txt"));
|
|
||||||
|
|
||||||
// sessionContext.ReconfigurationFilePath = resource.LocalPath;
|
var result = sut.Repeat();
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null)).Returns(LoadStatus.Success);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.Never);
|
||||||
|
Assert.AreEqual(OperationResult.Failed, result);
|
||||||
|
|
||||||
// var result = sut.Repeat();
|
sessionContext.ReconfigurationFilePath = resource.LocalPath;
|
||||||
|
result = sut.Repeat();
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null), Times.Once);
|
repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, It.IsAny<PasswordParameters>()), Times.Never);
|
||||||
|
Assert.AreEqual(OperationResult.Failed, result);
|
||||||
// Assert.AreEqual(OperationResult.Success, result);
|
}
|
||||||
//}
|
|
||||||
|
|
||||||
//[TestMethod]
|
|
||||||
//public void MustFailToReconfigureWithInvalidUri()
|
|
||||||
//{
|
|
||||||
// var resource = new Uri("file:///C:/does/not/exist.txt");
|
|
||||||
|
|
||||||
// sessionContext.ReconfigurationFilePath = null;
|
|
||||||
// repository.Setup(r => r.TryLoadSettings(It.IsAny<Uri>(), out settings, null)).Returns(LoadStatus.Success);
|
|
||||||
|
|
||||||
// sut = new ConfigurationOperation(null, repository.Object, logger.Object, sessionContext);
|
|
||||||
|
|
||||||
// var result = sut.Repeat();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null), Times.Never);
|
|
||||||
// Assert.AreEqual(OperationResult.Failed, result);
|
|
||||||
|
|
||||||
// sessionContext.ReconfigurationFilePath = resource.LocalPath;
|
|
||||||
// result = sut.Repeat();
|
|
||||||
|
|
||||||
// repository.Verify(r => r.TryLoadSettings(It.Is<Uri>(u => u.Equals(resource)), out settings, null), Times.Never);
|
|
||||||
// Assert.AreEqual(OperationResult.Failed, result);
|
|
||||||
//}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue