Update Safe Exam Browser Patch to 3.10.0.826

This commit is contained in:
2025-09-16 16:32:31 +02:00
parent 4827ae1afc
commit dd82d45ed8
320 changed files with 8445 additions and 5295 deletions

View File

@@ -16,9 +16,13 @@ using SafeExamBrowser.Communication.Contracts.Hosts;
using SafeExamBrowser.Communication.Contracts.Proxies;
using SafeExamBrowser.Configuration.Contracts;
using SafeExamBrowser.Core.Contracts.OperationModel;
using SafeExamBrowser.I18n.Contracts;
using SafeExamBrowser.Logging.Contracts;
using SafeExamBrowser.Runtime.Operations;
using SafeExamBrowser.Runtime.Communication;
using SafeExamBrowser.Runtime.Operations.Session;
using SafeExamBrowser.Settings;
using SafeExamBrowser.UserInterface.Contracts.MessageBox;
using SafeExamBrowser.UserInterface.Contracts.Windows;
using SafeExamBrowser.WindowsApi.Contracts;
namespace SafeExamBrowser.Runtime.UnitTests.Operations
@@ -29,20 +33,24 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
private Action clientReady;
private Action terminated;
private AppConfig appConfig;
private Dependencies dependencies;
private Mock<IClientProxy> proxy;
private Mock<ILogger> logger;
private Mock<IProcess> process;
private Mock<IProcessFactory> processFactory;
private Mock<IProxyFactory> proxyFactory;
private RuntimeContext runtimeContext;
private Mock<IRuntimeHost> runtimeHost;
private SessionConfiguration session;
private SessionContext sessionContext;
private AppSettings settings;
private ClientOperation sut;
[TestInitialize]
public void Initialize()
{
runtimeContext = new RuntimeContext();
runtimeHost = new Mock<IRuntimeHost>();
appConfig = new AppConfig();
clientReady = new Action(() => runtimeHost.Raise(h => h.ClientReady += null));
logger = new Mock<ILogger>();
@@ -50,9 +58,7 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
processFactory = new Mock<IProcessFactory>();
proxy = new Mock<IClientProxy>();
proxyFactory = new Mock<IProxyFactory>();
runtimeHost = new Mock<IRuntimeHost>();
session = new SessionConfiguration();
sessionContext = new SessionContext();
settings = new AppSettings();
terminated = new Action(() =>
{
@@ -63,11 +69,19 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
appConfig.ClientLogFilePath = "";
session.AppConfig = appConfig;
session.Settings = settings;
sessionContext.Current = session;
sessionContext.Next = session;
runtimeContext.Current = session;
runtimeContext.Next = session;
dependencies = new Dependencies(
new ClientBridge(Mock.Of<IRuntimeHost>(), runtimeContext),
logger.Object,
Mock.Of<IMessageBox>(),
Mock.Of<IRuntimeWindow>(),
runtimeContext,
Mock.Of<IText>());
proxyFactory.Setup(f => f.CreateClientProxy(It.IsAny<string>(), It.IsAny<Interlocutor>())).Returns(proxy.Object);
sut = new ClientOperation(logger.Object, processFactory.Object, proxyFactory.Object, runtimeHost.Object, sessionContext, 0);
sut = new ClientOperation(dependencies, processFactory.Object, proxyFactory.Object, runtimeHost.Object, 0);
}
[TestMethod]
@@ -84,8 +98,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
result = sut.Perform();
Assert.AreEqual(process.Object, sessionContext.ClientProcess);
Assert.AreEqual(proxy.Object, sessionContext.ClientProxy);
Assert.AreEqual(process.Object, runtimeContext.ClientProcess);
Assert.AreEqual(proxy.Object, runtimeContext.ClientProxy);
Assert.AreEqual(OperationResult.Success, result);
}
@@ -100,7 +114,7 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
var terminateClient = new Action(() => Task.Delay(100).ContinueWith(_ => process.Raise(p => p.Terminated += null, 0)));
processFactory.Setup(f => f.StartNew(It.IsAny<string>(), It.IsAny<string[]>())).Returns(process.Object).Callback(terminateClient);
sut = new ClientOperation(logger.Object, processFactory.Object, proxyFactory.Object, runtimeHost.Object, sessionContext, ONE_SECOND);
sut = new ClientOperation(dependencies, processFactory.Object, proxyFactory.Object, runtimeHost.Object, ONE_SECOND);
before = DateTime.Now;
result = sut.Perform();
@@ -120,8 +134,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
result = sut.Perform();
Assert.IsNotNull(sessionContext.ClientProcess);
Assert.IsNotNull(sessionContext.ClientProxy);
Assert.IsNotNull(runtimeContext.ClientProcess);
Assert.IsNotNull(runtimeContext.ClientProxy);
Assert.AreEqual(OperationResult.Failed, result);
}
@@ -139,8 +153,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
result = sut.Perform();
Assert.IsNotNull(sessionContext.ClientProcess);
Assert.IsNotNull(sessionContext.ClientProxy);
Assert.IsNotNull(runtimeContext.ClientProcess);
Assert.IsNotNull(runtimeContext.ClientProxy);
Assert.AreEqual(OperationResult.Failed, result);
}
@@ -158,8 +172,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
result = sut.Repeat();
Assert.AreEqual(process.Object, sessionContext.ClientProcess);
Assert.AreEqual(proxy.Object, sessionContext.ClientProxy);
Assert.AreEqual(process.Object, runtimeContext.ClientProcess);
Assert.AreEqual(proxy.Object, runtimeContext.ClientProxy);
Assert.AreEqual(OperationResult.Success, result);
}
@@ -175,8 +189,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
proxy.Verify(p => p.Disconnect(), Times.Once);
process.Verify(p => p.TryKill(It.IsAny<int>()), Times.Never);
Assert.IsNull(sessionContext.ClientProcess);
Assert.IsNull(sessionContext.ClientProxy);
Assert.IsNull(runtimeContext.ClientProcess);
Assert.IsNull(runtimeContext.ClientProxy);
}
[TestMethod]
@@ -189,8 +203,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
process.Verify(p => p.TryKill(It.IsAny<int>()), Times.AtLeastOnce);
Assert.IsNull(sessionContext.ClientProcess);
Assert.IsNull(sessionContext.ClientProxy);
Assert.IsNull(runtimeContext.ClientProcess);
Assert.IsNull(runtimeContext.ClientProxy);
}
[TestMethod]
@@ -201,8 +215,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
process.Verify(p => p.TryKill(It.IsAny<int>()), Times.Exactly(5));
Assert.IsNotNull(sessionContext.ClientProcess);
Assert.IsNotNull(sessionContext.ClientProxy);
Assert.IsNotNull(runtimeContext.ClientProcess);
Assert.IsNotNull(runtimeContext.ClientProxy);
}
[TestMethod]
@@ -216,8 +230,8 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
proxy.Verify(p => p.Disconnect(), Times.Never);
process.Verify(p => p.TryKill(It.IsAny<int>()), Times.Never);
Assert.IsNull(sessionContext.ClientProcess);
Assert.IsNull(sessionContext.ClientProxy);
Assert.IsNull(runtimeContext.ClientProcess);
Assert.IsNull(runtimeContext.ClientProxy);
}
private void PerformNormally()