2023-05-30 18:08:50 +02:00
|
|
|
|
/*
|
2024-03-05 18:37:42 +01:00
|
|
|
|
* Copyright (c) 2024 ETH Zürich, IT Services
|
2023-05-30 18:08:50 +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 Microsoft.VisualStudio.TestTools.UnitTesting;
|
|
|
|
|
using Moq;
|
|
|
|
|
using SafeExamBrowser.Applications.Contracts;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
|
|
|
|
using SafeExamBrowser.Monitoring.Contracts.Applications;
|
|
|
|
|
using SafeExamBrowser.Settings.Applications;
|
2023-06-01 18:18:01 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Contracts.Registry;
|
2023-05-30 18:08:50 +02:00
|
|
|
|
using SafeExamBrowser.WindowsApi.Contracts;
|
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Applications.UnitTests
|
|
|
|
|
{
|
|
|
|
|
[TestClass]
|
|
|
|
|
public class ApplicationFactoryTests
|
|
|
|
|
{
|
|
|
|
|
private Mock<IApplicationMonitor> applicationMonitor;
|
|
|
|
|
private Mock<IModuleLogger> logger;
|
|
|
|
|
private Mock<INativeMethods> nativeMethods;
|
|
|
|
|
private Mock<IProcessFactory> processFactory;
|
2023-06-01 18:18:01 +02:00
|
|
|
|
private Mock<IRegistry> registry;
|
2023-05-30 18:08:50 +02:00
|
|
|
|
|
|
|
|
|
private ApplicationFactory sut;
|
|
|
|
|
|
|
|
|
|
[TestInitialize]
|
|
|
|
|
public void Initialize()
|
|
|
|
|
{
|
|
|
|
|
applicationMonitor = new Mock<IApplicationMonitor>();
|
|
|
|
|
logger = new Mock<IModuleLogger>();
|
|
|
|
|
nativeMethods = new Mock<INativeMethods>();
|
|
|
|
|
processFactory = new Mock<IProcessFactory>();
|
2023-06-01 18:18:01 +02:00
|
|
|
|
registry = new Mock<IRegistry>();
|
2023-05-30 18:08:50 +02:00
|
|
|
|
|
2023-06-01 18:18:01 +02:00
|
|
|
|
sut = new ApplicationFactory(applicationMonitor.Object, logger.Object, nativeMethods.Object, processFactory.Object, registry.Object);
|
2023-05-30 18:08:50 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustCorrectlyCreateApplication()
|
|
|
|
|
{
|
|
|
|
|
var settings = new WhitelistApplication
|
|
|
|
|
{
|
|
|
|
|
DisplayName = "Windows Command Prompt",
|
|
|
|
|
ExecutableName = "cmd.exe",
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var result = sut.TryCreate(settings, out var application);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(FactoryResult.Success, result);
|
|
|
|
|
Assert.IsNotNull(application);
|
|
|
|
|
Assert.IsInstanceOfType<ExternalApplication>(application);
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-01 18:18:01 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustCorrectlyReadPathFromRegistry()
|
|
|
|
|
{
|
2023-06-02 14:08:11 +02:00
|
|
|
|
object o = @"C:\Some\Registry\Path";
|
2023-06-01 18:18:01 +02:00
|
|
|
|
var settings = new WhitelistApplication
|
|
|
|
|
{
|
|
|
|
|
DisplayName = "Windows Command Prompt",
|
|
|
|
|
ExecutableName = "cmd.exe",
|
2023-06-02 14:08:11 +02:00
|
|
|
|
ExecutablePath = @"C:\Some\Path"
|
2023-06-01 18:18:01 +02:00
|
|
|
|
};
|
|
|
|
|
|
2023-06-02 14:08:11 +02:00
|
|
|
|
registry.Setup(r => r.TryRead(It.Is<string>(s => s.Contains(RegistryValue.MachineHive.AppPaths_Key)), It.Is<string>(s => s == "Path"), out o)).Returns(true);
|
|
|
|
|
|
2023-06-01 18:18:01 +02:00
|
|
|
|
var result = sut.TryCreate(settings, out var application);
|
|
|
|
|
|
|
|
|
|
registry.Verify(r => r.TryRead(It.Is<string>(s => s.Contains(RegistryValue.MachineHive.AppPaths_Key)), It.Is<string>(s => s == "Path"), out o), Times.Once);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(FactoryResult.Success, result);
|
|
|
|
|
Assert.IsNotNull(application);
|
|
|
|
|
Assert.IsInstanceOfType<ExternalApplication>(application);
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-30 18:08:50 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustIndicateIfApplicationNotFound()
|
|
|
|
|
{
|
|
|
|
|
var settings = new WhitelistApplication
|
|
|
|
|
{
|
2023-06-01 18:18:01 +02:00
|
|
|
|
ExecutableName = "some_random_application_which_does_not_exist_on_a_normal_system.exe",
|
|
|
|
|
ExecutablePath = "Some/Path/Which/Does/Not/Exist"
|
2023-05-30 18:08:50 +02:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var result = sut.TryCreate(settings, out var application);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(FactoryResult.NotFound, result);
|
|
|
|
|
Assert.IsNull(application);
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-02 14:08:11 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustFailGracefullyWhenPathIsInvalid()
|
|
|
|
|
{
|
|
|
|
|
var settings = new WhitelistApplication
|
|
|
|
|
{
|
|
|
|
|
ExecutableName = "asdfg(/ç)&=%\"fsdg..exe..",
|
|
|
|
|
ExecutablePath = "[]#°§¬#°¢@tu03450'w89tz!$£äöüèé:"
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var result = sut.TryCreate(settings, out _);
|
|
|
|
|
|
|
|
|
|
logger.Verify(l => l.Error(It.IsAny<string>(), It.IsAny<Exception>()), Times.AtLeastOnce);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(FactoryResult.NotFound, result);
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-30 18:08:50 +02:00
|
|
|
|
[TestMethod]
|
|
|
|
|
public void MustFailGracefullyAndIndicateThatErrorOccurred()
|
|
|
|
|
{
|
2023-06-01 18:18:01 +02:00
|
|
|
|
var o = default(object);
|
|
|
|
|
var settings = new WhitelistApplication();
|
2023-05-30 18:08:50 +02:00
|
|
|
|
|
2023-06-01 18:18:01 +02:00
|
|
|
|
registry.Setup(r => r.TryRead(It.IsAny<string>(), It.IsAny<string>(), out o)).Throws<Exception>();
|
2023-05-30 18:08:50 +02:00
|
|
|
|
|
|
|
|
|
var result = sut.TryCreate(settings, out var application);
|
|
|
|
|
|
|
|
|
|
Assert.AreEqual(FactoryResult.Error, result);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|