SessionTest_Connected_ServerSendsDisconnectMessageAndShutsDownSocket.cs 6.4 KB

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