From a1abc662b8bb5531a981fc5a923a84156c38f422 Mon Sep 17 00:00:00 2001 From: dbuechel Date: Fri, 15 Feb 2019 09:26:54 +0100 Subject: [PATCH] SEBWIN-296: Extended unit tests for client host. --- .../Communication/ClientHostTests.cs | 39 ++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) diff --git a/SafeExamBrowser.Client.UnitTests/Communication/ClientHostTests.cs b/SafeExamBrowser.Client.UnitTests/Communication/ClientHostTests.cs index a2cfe768..2f173b6e 100644 --- a/SafeExamBrowser.Client.UnitTests/Communication/ClientHostTests.cs +++ b/SafeExamBrowser.Client.UnitTests/Communication/ClientHostTests.cs @@ -16,6 +16,7 @@ using SafeExamBrowser.Contracts.Communication.Data; using SafeExamBrowser.Contracts.Communication.Hosts; using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Logging; +using SafeExamBrowser.Contracts.UserInterface.MessageBox; namespace SafeExamBrowser.Client.UnitTests.Communication { @@ -50,7 +51,13 @@ namespace SafeExamBrowser.Client.UnitTests.Communication sut.StartupToken = token; - var response = sut.Connect(token); + var response = sut.Connect(Guid.Empty); + + Assert.IsNotNull(response); + Assert.IsFalse(response.ConnectionEstablished); + Assert.IsFalse(sut.IsConnected); + + response = sut.Connect(token); Assert.IsNotNull(response); Assert.IsTrue(response.ConnectionEstablished); @@ -125,6 +132,36 @@ namespace SafeExamBrowser.Client.UnitTests.Communication Assert.AreEqual(PROCESS_ID, (response as AuthenticationResponse)?.ProcessId); } + [TestMethod] + public void MustHandleMessageBoxRequestCorrectly() + { + var action = MessageBoxAction.YesNo; + var icon = MessageBoxIcon.Question; + var message = "Qwert kndorz safie abcd?"; + var messageBoxRequested = false; + var requestId = Guid.NewGuid(); + var resetEvent = new AutoResetEvent(false); + var title = "Poiuztrewq!"; + + sut.MessageBoxRequested += (args) => + { + messageBoxRequested = args.Action == action && args.Icon == icon && args.Message == message && args.RequestId == requestId && args.Title == title; + resetEvent.Set(); + }; + sut.StartupToken = Guid.Empty; + + var token = sut.Connect(Guid.Empty).CommunicationToken.Value; + var request = new MessageBoxRequestMessage(action, icon, message, requestId, title) { CommunicationToken = token }; + var response = sut.Send(request); + + resetEvent.WaitOne(); + + Assert.IsTrue(messageBoxRequested); + Assert.IsNotNull(response); + Assert.IsInstanceOfType(response, typeof(SimpleResponse)); + Assert.AreEqual(SimpleResponsePurport.Acknowledged, (response as SimpleResponse)?.Purport); + } + [TestMethod] public void MustHandlePasswordRequestCorrectly() {