SessionTest_Connected_ServerSendsBadPacket.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. using System.Diagnostics;
  2. using System.Net.Sockets;
  3. using System.Threading;
  4. using Microsoft.VisualStudio.TestTools.UnitTesting;
  5. using Renci.SshNet.Common;
  6. using Renci.SshNet.Messages.Transport;
  7. using Renci.SshNet.Tests.Common;
  8. namespace Renci.SshNet.Tests.Classes
  9. {
  10. [TestClass]
  11. public class SessionTest_Connected_ServerSendsBadPacket : SessionTest_ConnectedBase
  12. {
  13. private byte[] _packet;
  14. protected override void SetupData()
  15. {
  16. base.SetupData();
  17. _packet = new byte[] {0x0a, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05};
  18. }
  19. protected override void Act()
  20. {
  21. _ = ServerSocket.Send(_packet, 0, _packet.Length, SocketFlags.None);
  22. // give session some time to process packet
  23. Thread.Sleep(200);
  24. }
  25. [TestMethod]
  26. public void IsConnectedShouldReturnFalse()
  27. {
  28. Assert.IsFalse(Session.IsConnected);
  29. }
  30. [TestMethod]
  31. public void DisconnectShouldFinishImmediately()
  32. {
  33. var stopwatch = new Stopwatch();
  34. stopwatch.Start();
  35. Session.Disconnect();
  36. stopwatch.Stop();
  37. Assert.IsTrue(stopwatch.ElapsedMilliseconds < 500);
  38. }
  39. [TestMethod]
  40. public void DisconnectedIsNeverRaised()
  41. {
  42. Assert.AreEqual(0, DisconnectedRegister.Count);
  43. }
  44. [TestMethod]
  45. public void DisconnectReceivedIsNeverRaised()
  46. {
  47. Assert.AreEqual(0, DisconnectReceivedRegister.Count);
  48. }
  49. [TestMethod]
  50. public void ErrorOccurredIsRaisedOnce()
  51. {
  52. Assert.AreEqual(1, ErrorOccurredRegister.Count, ErrorOccurredRegister.AsString());
  53. var errorOccurred = ErrorOccurredRegister[0];
  54. Assert.IsNotNull(errorOccurred);
  55. var exception = errorOccurred.Exception;
  56. Assert.IsNotNull(exception);
  57. Assert.AreEqual(typeof(SshConnectionException), exception.GetType());
  58. var connectionException = (SshConnectionException) exception;
  59. Assert.AreEqual(DisconnectReason.ProtocolError, connectionException.DisconnectReason);
  60. Assert.IsNull(connectionException.InnerException);
  61. Assert.AreEqual("Bad packet length: 168101125.", connectionException.Message);
  62. }
  63. [TestMethod]
  64. public void DisposeShouldFinishImmediately()
  65. {
  66. var stopwatch = new Stopwatch();
  67. stopwatch.Start();
  68. Session.Dispose();
  69. stopwatch.Stop();
  70. Assert.IsTrue(stopwatch.ElapsedMilliseconds < 500);
  71. }
  72. [TestMethod]
  73. public void ReceiveOnServerSocketShouldReturnZero()
  74. {
  75. var buffer = new byte[1];
  76. var actual = ServerSocket.Receive(buffer, 0, buffer.Length, SocketFlags.None);
  77. Assert.AreEqual(0, actual);
  78. }
  79. [TestMethod]
  80. public void SendMessageShouldThrowSshConnectionException()
  81. {
  82. try
  83. {
  84. Session.SendMessage(new IgnoreMessage());
  85. Assert.Fail();
  86. }
  87. catch (SshConnectionException ex)
  88. {
  89. Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
  90. Assert.IsNull(ex.InnerException);
  91. Assert.AreEqual("Client not connected.", ex.Message);
  92. }
  93. }
  94. [TestMethod]
  95. public void ISession_MessageListenerCompletedShouldBeSignaled()
  96. {
  97. var session = (ISession) Session;
  98. Assert.IsNotNull(session.MessageListenerCompleted);
  99. Assert.IsTrue(session.MessageListenerCompleted.WaitOne());
  100. }
  101. [TestMethod]
  102. public void ISession_SendMessageShouldThrowSshConnectionException()
  103. {
  104. var session = (ISession) Session;
  105. try
  106. {
  107. session.SendMessage(new IgnoreMessage());
  108. Assert.Fail();
  109. }
  110. catch (SshConnectionException ex)
  111. {
  112. Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
  113. Assert.IsNull(ex.InnerException);
  114. Assert.AreEqual("Client not connected.", ex.Message);
  115. }
  116. }
  117. [TestMethod]
  118. public void ISession_TrySendMessageShouldReturnFalse()
  119. {
  120. var session = (ISession) Session;
  121. var actual = session.TrySendMessage(new IgnoreMessage());
  122. Assert.IsFalse(actual);
  123. }
  124. [TestMethod]
  125. public void ISession_WaitOnHandle_WaitHandle_ShouldThrowSshConnectionExceptionDetailingBadPacket()
  126. {
  127. var session = (ISession) Session;
  128. var waitHandle = new ManualResetEvent(false);
  129. try
  130. {
  131. session.WaitOnHandle(waitHandle);
  132. Assert.Fail();
  133. }
  134. catch (SshConnectionException ex)
  135. {
  136. Assert.AreEqual(DisconnectReason.ProtocolError, ex.DisconnectReason);
  137. Assert.IsNull(ex.InnerException);
  138. Assert.AreEqual("Bad packet length: 168101125.", ex.Message);
  139. }
  140. }
  141. [TestMethod]
  142. public void ISession_WaitOnHandleAndTimeout_WaitHandle_ShouldThrowSshConnectionExceptionDetailingBadPacket()
  143. {
  144. var session = (ISession) Session;
  145. var waitHandle = new ManualResetEvent(false);
  146. try
  147. {
  148. session.WaitOnHandle(waitHandle, Timeout.InfiniteTimeSpan);
  149. Assert.Fail();
  150. }
  151. catch (SshConnectionException ex)
  152. {
  153. Assert.AreEqual(DisconnectReason.ProtocolError, ex.DisconnectReason);
  154. Assert.IsNull(ex.InnerException);
  155. Assert.AreEqual("Bad packet length: 168101125.", ex.Message);
  156. }
  157. }
  158. [TestMethod]
  159. public void ISession_TryWait_WaitHandleAndTimeout_ShouldReturnDisconnected()
  160. {
  161. var session = (ISession) Session;
  162. var waitHandle = new ManualResetEvent(false);
  163. var result = session.TryWait(waitHandle, Timeout.InfiniteTimeSpan);
  164. Assert.AreEqual(WaitResult.Disconnected, result);
  165. }
  166. [TestMethod]
  167. public void ISession_TryWait_WaitHandleAndTimeoutAndException_ShouldReturnDisconnected()
  168. {
  169. var session = (ISession) Session;
  170. var waitHandle = new ManualResetEvent(false);
  171. var result = session.TryWait(waitHandle, Timeout.InfiniteTimeSpan, out var exception);
  172. Assert.AreEqual(WaitResult.Disconnected, result);
  173. Assert.IsNull(exception);
  174. }
  175. }
  176. }