SEBWIN-220: Extended unit tests for proxies.
This commit is contained in:
		
							parent
							
								
									c32028d3dd
								
							
						
					
					
						commit
						72425f0d6c
					
				
					 3 changed files with 117 additions and 2 deletions
				
			
		|  | @ -105,6 +105,21 @@ namespace SafeExamBrowser.Core.UnitTests.Communication.Proxies | ||||||
| 			Assert.IsFalse(connected); | 			Assert.IsFalse(connected); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustHandleConnectionFailureCorrectly() | ||||||
|  | 		{ | ||||||
|  | 			var proxy = new Mock<IProxyObject>(); | ||||||
|  | 
 | ||||||
|  | 			proxyObjectFactory.Setup(f => f.CreateObject(It.IsAny<string>())).Throws<Exception>(); | ||||||
|  | 
 | ||||||
|  | 			var token = Guid.NewGuid(); | ||||||
|  | 			var connected = sut.Connect(token); | ||||||
|  | 
 | ||||||
|  | 			proxyObjectFactory.Verify(f => f.CreateObject(It.IsAny<string>()), Times.Once); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsFalse(connected); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		[TestMethod] | 		[TestMethod] | ||||||
| 		public void MustFailToDisconnectIfNotConnected() | 		public void MustFailToDisconnectIfNotConnected() | ||||||
| 		{ | 		{ | ||||||
|  |  | ||||||
|  | @ -58,7 +58,7 @@ namespace SafeExamBrowser.Core.UnitTests.Communication.Proxies | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		[TestMethod] | 		[TestMethod] | ||||||
| 		public void MustIndicateIfShutdownCommandNotAcknowledged() | 		public void MustFailIfShutdownCommandNotAcknowledged() | ||||||
| 		{ | 		{ | ||||||
| 			proxy.Setup(p => p.Send(It.Is<SimpleMessage>(m => m.Purport == SimpleMessagePurport.Shutdown))).Returns<Response>(null); | 			proxy.Setup(p => p.Send(It.Is<SimpleMessage>(m => m.Purport == SimpleMessagePurport.Shutdown))).Returns<Response>(null); | ||||||
| 
 | 
 | ||||||
|  | @ -82,7 +82,7 @@ namespace SafeExamBrowser.Core.UnitTests.Communication.Proxies | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		[TestMethod] | 		[TestMethod] | ||||||
| 		public void MustIndicateIfAuthenticationCommandNotAcknowledged() | 		public void MustFailIfAuthenticationCommandNotAcknowledged() | ||||||
| 		{ | 		{ | ||||||
| 			proxy.Setup(p => p.Send(It.Is<SimpleMessage>(m => m.Purport == SimpleMessagePurport.Authenticate))).Returns<Response>(null); | 			proxy.Setup(p => p.Send(It.Is<SimpleMessage>(m => m.Purport == SimpleMessagePurport.Authenticate))).Returns<Response>(null); | ||||||
| 
 | 
 | ||||||
|  | @ -91,5 +91,63 @@ namespace SafeExamBrowser.Core.UnitTests.Communication.Proxies | ||||||
| 			Assert.AreEqual(default(AuthenticationResponse), communication.Value); | 			Assert.AreEqual(default(AuthenticationResponse), communication.Value); | ||||||
| 			Assert.IsFalse(communication.Success); | 			Assert.IsFalse(communication.Success); | ||||||
| 		} | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustCorrectlyInformAboutReconfigurationDenial() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<ReconfigurationDeniedMessage>())).Returns(new SimpleResponse(SimpleResponsePurport.Acknowledged)); | ||||||
|  | 
 | ||||||
|  | 			var communication = sut.InformReconfigurationDenied(null); | ||||||
|  | 
 | ||||||
|  | 			proxy.Verify(p => p.Send(It.IsAny<ReconfigurationDeniedMessage>()), Times.Once); | ||||||
|  | 			Assert.IsTrue(communication.Success); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustFailIfReconfigurationDenialNotAcknowledged() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<ReconfigurationDeniedMessage>())).Returns<Response>(null); | ||||||
|  | 
 | ||||||
|  | 			var communication = sut.InformReconfigurationDenied(null); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsFalse(communication.Success); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustCorrectlyRequestPassword() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<PasswordRequestMessage>())).Returns(new SimpleResponse(SimpleResponsePurport.Acknowledged)); | ||||||
|  | 
 | ||||||
|  | 			var communication = sut.RequestPassword(default(PasswordRequestPurpose), default(Guid)); | ||||||
|  | 
 | ||||||
|  | 			proxy.Verify(p => p.Send(It.IsAny<PasswordRequestMessage>()), Times.Once); | ||||||
|  | 			Assert.IsTrue(communication.Success); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustFailIfPasswordRequestNotAcknowledged() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<PasswordRequestMessage>())).Returns<Response>(null); | ||||||
|  | 
 | ||||||
|  | 			var communication = sut.RequestPassword(default(PasswordRequestPurpose), default(Guid)); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsFalse(communication.Success); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustExecuteOperationsFailsafe() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<Message>())).Throws<Exception>(); | ||||||
|  | 
 | ||||||
|  | 			var authenticate = sut.RequestAuthentication(); | ||||||
|  | 			var password = sut.RequestPassword(default(PasswordRequestPurpose), default(Guid)); | ||||||
|  | 			var reconfiguration = sut.InformReconfigurationDenied(null); | ||||||
|  | 			var shutdown = sut.InitiateShutdown(); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsFalse(authenticate.Success); | ||||||
|  | 			Assert.IsFalse(password.Success); | ||||||
|  | 			Assert.IsFalse(reconfiguration.Success); | ||||||
|  | 			Assert.IsFalse(shutdown.Success); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -142,5 +142,47 @@ namespace SafeExamBrowser.Core.UnitTests.Communication.Proxies | ||||||
| 
 | 
 | ||||||
| 			Assert.IsFalse(communication.Success); | 			Assert.IsFalse(communication.Success); | ||||||
| 		} | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustCorrectlySubmitPassword() | ||||||
|  | 		{ | ||||||
|  | 			var password = "blubb"; | ||||||
|  | 			var requestId = Guid.NewGuid(); | ||||||
|  | 
 | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<PasswordReplyMessage>())).Returns(new SimpleResponse(SimpleResponsePurport.Acknowledged)); | ||||||
|  | 
 | ||||||
|  | 			var communication = sut.SubmitPassword(requestId, true, password); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsTrue(communication.Success); | ||||||
|  | 			proxy.Verify(p => p.Send(It.Is<PasswordReplyMessage>(m => m.Password == password && m.RequestId == requestId && m.Success)), Times.Once); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustFailIfPasswordTransmissionNotAcknowledged() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<PasswordReplyMessage>())).Returns<Response>(null); | ||||||
|  | 
 | ||||||
|  | 			var communication = sut.SubmitPassword(default(Guid), false); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsFalse(communication.Success); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		[TestMethod] | ||||||
|  | 		public void MustExecuteOperationsFailsafe() | ||||||
|  | 		{ | ||||||
|  | 			proxy.Setup(p => p.Send(It.IsAny<Message>())).Throws<Exception>(); | ||||||
|  | 
 | ||||||
|  | 			var client = sut.InformClientReady(); | ||||||
|  | 			var configuration = sut.GetConfiguration(); | ||||||
|  | 			var password = sut.SubmitPassword(default(Guid), false); | ||||||
|  | 			var reconfiguration = sut.RequestReconfiguration(null); | ||||||
|  | 			var shutdown = sut.RequestShutdown(); | ||||||
|  | 
 | ||||||
|  | 			Assert.IsFalse(client.Success); | ||||||
|  | 			Assert.IsFalse(configuration.Success); | ||||||
|  | 			Assert.IsFalse(password.Success); | ||||||
|  | 			Assert.IsFalse(reconfiguration.Success); | ||||||
|  | 			Assert.IsFalse(shutdown.Success); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 dbuechel
						dbuechel