2
0

SessionTest_Connected_ServerSendsBadPacket.cs 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  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 ServerShouldBeDisconnected()
  74. {
  75. try
  76. {
  77. var buffer = new byte[1];
  78. var actual = ServerSocket.Receive(buffer, 0, buffer.Length, SocketFlags.None);
  79. Assert.AreEqual(0, actual); // FIN
  80. }
  81. catch (SocketException sx)
  82. {
  83. Assert.AreEqual(SocketError.ConnectionReset, sx.SocketErrorCode); // RST
  84. }
  85. }
  86. [TestMethod]
  87. public void SendMessageShouldThrowSshConnectionException()
  88. {
  89. try
  90. {
  91. Session.SendMessage(new IgnoreMessage());
  92. Assert.Fail();
  93. }
  94. catch (SshConnectionException ex)
  95. {
  96. Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
  97. Assert.IsNull(ex.InnerException);
  98. Assert.AreEqual("Client not connected.", ex.Message);
  99. }
  100. }
  101. [TestMethod]
  102. public void ISession_MessageListenerCompletedShouldBeSignaled()
  103. {
  104. var session = (ISession)Session;
  105. Assert.IsNotNull(session.MessageListenerCompleted);
  106. Assert.IsTrue(session.MessageListenerCompleted.WaitOne());
  107. }
  108. [TestMethod]
  109. public void ISession_SendMessageShouldThrowSshConnectionException()
  110. {
  111. var session = (ISession)Session;
  112. try
  113. {
  114. session.SendMessage(new IgnoreMessage());
  115. Assert.Fail();
  116. }
  117. catch (SshConnectionException ex)
  118. {
  119. Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
  120. Assert.IsNull(ex.InnerException);
  121. Assert.AreEqual("Client not connected.", ex.Message);
  122. }
  123. }
  124. [TestMethod]
  125. public void ISession_TrySendMessageShouldReturnFalse()
  126. {
  127. var session = (ISession)Session;
  128. var actual = session.TrySendMessage(new IgnoreMessage());
  129. Assert.IsFalse(actual);
  130. }
  131. [TestMethod]
  132. public void ISession_WaitOnHandle_WaitHandle_ShouldThrowSshConnectionExceptionDetailingBadPacket()
  133. {
  134. var session = (ISession)Session;
  135. var waitHandle = new ManualResetEvent(false);
  136. try
  137. {
  138. session.WaitOnHandle(waitHandle);
  139. Assert.Fail();
  140. }
  141. catch (SshConnectionException ex)
  142. {
  143. Assert.AreEqual(DisconnectReason.ProtocolError, ex.DisconnectReason);
  144. Assert.IsNull(ex.InnerException);
  145. Assert.AreEqual("Bad packet length: 168101125.", ex.Message);
  146. }
  147. }
  148. [TestMethod]
  149. public void ISession_WaitOnHandleAndTimeout_WaitHandle_ShouldThrowSshConnectionExceptionDetailingBadPacket()
  150. {
  151. var session = (ISession)Session;
  152. var waitHandle = new ManualResetEvent(false);
  153. try
  154. {
  155. session.WaitOnHandle(waitHandle, Timeout.InfiniteTimeSpan);
  156. Assert.Fail();
  157. }
  158. catch (SshConnectionException ex)
  159. {
  160. Assert.AreEqual(DisconnectReason.ProtocolError, ex.DisconnectReason);
  161. Assert.IsNull(ex.InnerException);
  162. Assert.AreEqual("Bad packet length: 168101125.", ex.Message);
  163. }
  164. }
  165. [TestMethod]
  166. public void ISession_TryWait_WaitHandleAndTimeout_ShouldReturnDisconnected()
  167. {
  168. var session = (ISession)Session;
  169. var waitHandle = new ManualResetEvent(false);
  170. var result = session.TryWait(waitHandle, Timeout.InfiniteTimeSpan);
  171. Assert.AreEqual(WaitResult.Disconnected, result);
  172. }
  173. [TestMethod]
  174. public void ISession_TryWait_WaitHandleAndTimeoutAndException_ShouldReturnDisconnected()
  175. {
  176. var session = (ISession)Session;
  177. var waitHandle = new ManualResetEvent(false);
  178. var result = session.TryWait(waitHandle, Timeout.InfiniteTimeSpan, out var exception);
  179. Assert.AreEqual(WaitResult.Disconnected, result);
  180. Assert.IsNull(exception);
  181. }
  182. }
  183. }