SessionTest_Connected_ServerSendsDisconnectMessage.cs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. using System.Diagnostics;
  2. using System.Globalization;
  3. using System.Net.Sockets;
  4. using System.Threading;
  5. using Microsoft.VisualStudio.TestTools.UnitTesting;
  6. using Renci.SshNet.Common;
  7. using Renci.SshNet.Messages.Transport;
  8. using Renci.SshNet.Tests.Common;
  9. namespace Renci.SshNet.Tests.Classes
  10. {
  11. [TestClass]
  12. public class SessionTest_Connected_ServerSendsDisconnectMessage : SessionTest_ConnectedBase
  13. {
  14. private byte[] _packet;
  15. private DisconnectMessage _disconnectMessage;
  16. protected override void SetupData()
  17. {
  18. base.SetupData();
  19. _disconnectMessage = new DisconnectMessage(DisconnectReason.ServiceNotAvailable, "Not today!");
  20. _packet = _disconnectMessage.GetPacket(8, null);
  21. }
  22. protected override void Act()
  23. {
  24. _ = ServerSocket.Send(_packet, 4, _packet.Length - 4, SocketFlags.None);
  25. // give session some time to process packet
  26. Thread.Sleep(200);
  27. }
  28. [TestMethod]
  29. public void IsConnectedShouldReturnFalse()
  30. {
  31. Assert.IsFalse(Session.IsConnected);
  32. }
  33. [TestMethod]
  34. public void DisconnectShouldFinishImmediately()
  35. {
  36. var stopwatch = new Stopwatch();
  37. stopwatch.Start();
  38. Session.Disconnect();
  39. stopwatch.Stop();
  40. Assert.IsTrue(stopwatch.ElapsedMilliseconds < 500);
  41. }
  42. [TestMethod]
  43. public void DisconnectedIsRaisedOnce()
  44. {
  45. Assert.AreEqual(1, DisconnectedRegister.Count);
  46. }
  47. [TestMethod]
  48. public void DisconnectReceivedIsRaisedOnce()
  49. {
  50. Assert.AreEqual(1, DisconnectReceivedRegister.Count);
  51. var disconnectMessage = DisconnectReceivedRegister[0].Message;
  52. Assert.IsNotNull(disconnectMessage);
  53. Assert.AreEqual(_disconnectMessage.Description, disconnectMessage.Description);
  54. Assert.AreEqual("en", disconnectMessage.Language);
  55. Assert.AreEqual(_disconnectMessage.ReasonCode, disconnectMessage.ReasonCode);
  56. }
  57. [TestMethod]
  58. public void ErrorOccurredIsNeverRaised()
  59. {
  60. Assert.AreEqual(0, ErrorOccurredRegister.Count, ErrorOccurredRegister.AsString());
  61. }
  62. [TestMethod]
  63. public void DisposeShouldFinishImmediately()
  64. {
  65. var stopwatch = new Stopwatch();
  66. stopwatch.Start();
  67. Session.Dispose();
  68. stopwatch.Stop();
  69. Assert.IsTrue(stopwatch.ElapsedMilliseconds < 500);
  70. }
  71. [TestMethod]
  72. public void ReceiveOnServerSocketShouldReturnZero()
  73. {
  74. var buffer = new byte[1];
  75. var actual = ServerSocket.Receive(buffer, 0, buffer.Length, SocketFlags.None);
  76. Assert.AreEqual(0, actual);
  77. }
  78. [TestMethod]
  79. public void SendMessageShouldThrowSshConnectionException()
  80. {
  81. try
  82. {
  83. Session.SendMessage(new IgnoreMessage());
  84. Assert.Fail();
  85. }
  86. catch (SshConnectionException ex)
  87. {
  88. Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
  89. Assert.IsNull(ex.InnerException);
  90. Assert.AreEqual("Client not connected.", ex.Message);
  91. }
  92. }
  93. [TestMethod]
  94. public void ISession_MessageListenerCompletedShouldBeSignaled()
  95. {
  96. var session = (ISession) Session;
  97. Assert.IsNotNull(session.MessageListenerCompleted);
  98. Assert.IsTrue(session.MessageListenerCompleted.WaitOne());
  99. }
  100. [TestMethod]
  101. public void ISession_SendMessageShouldThrowSshConnectionException()
  102. {
  103. var session = (ISession) Session;
  104. try
  105. {
  106. session.SendMessage(new IgnoreMessage());
  107. Assert.Fail();
  108. }
  109. catch (SshConnectionException ex)
  110. {
  111. Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
  112. Assert.IsNull(ex.InnerException);
  113. Assert.AreEqual("Client not connected.", ex.Message);
  114. }
  115. }
  116. [TestMethod]
  117. public void ISession_TrySendMessageShouldReturnFalse()
  118. {
  119. var session = (ISession) Session;
  120. var actual = session.TrySendMessage(new IgnoreMessage());
  121. Assert.IsFalse(actual);
  122. }
  123. [TestMethod]
  124. public void ISession_WaitOnHandle_WaitHandle_ShouldThrowSshConnectionExceptionDetailingDisconnectReason()
  125. {
  126. var session = (ISession) Session;
  127. var waitHandle = new ManualResetEvent(false);
  128. try
  129. {
  130. session.WaitOnHandle(waitHandle);
  131. Assert.Fail();
  132. }
  133. catch (SshConnectionException ex)
  134. {
  135. Assert.AreEqual(DisconnectReason.ServiceNotAvailable, ex.DisconnectReason);
  136. Assert.IsNull(ex.InnerException);
  137. Assert.AreEqual(string.Format(CultureInfo.InvariantCulture,
  138. "The connection was closed by the server: {0} ({1}).",
  139. _disconnectMessage.Description,
  140. _disconnectMessage.ReasonCode),
  141. ex.Message);
  142. }
  143. }
  144. [TestMethod]
  145. public void ISession_WaitOnHandle_WaitHandleAndTimeout_ShouldThrowSshConnectionExceptionDetailingDisconnectReason()
  146. {
  147. var session = (ISession) Session;
  148. var waitHandle = new ManualResetEvent(false);
  149. try
  150. {
  151. session.WaitOnHandle(waitHandle, Session.InfiniteTimeSpan);
  152. Assert.Fail();
  153. }
  154. catch (SshConnectionException ex)
  155. {
  156. Assert.AreEqual(DisconnectReason.ServiceNotAvailable, ex.DisconnectReason);
  157. Assert.IsNull(ex.InnerException);
  158. Assert.AreEqual(string.Format(CultureInfo.InvariantCulture,
  159. "The connection was closed by the server: {0} ({1}).",
  160. _disconnectMessage.Description,
  161. _disconnectMessage.ReasonCode),
  162. 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, Session.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, Session.InfiniteTimeSpan, out var exception);
  179. Assert.AreEqual(WaitResult.Disconnected, result);
  180. Assert.IsNull(exception);
  181. }
  182. }
  183. }