| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- using System.Diagnostics;
- using System.Globalization;
- using System.Net.Sockets;
- using System.Threading;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Renci.SshNet.Common;
- using Renci.SshNet.Messages.Transport;
- using Renci.SshNet.Tests.Common;
- namespace Renci.SshNet.Tests.Classes
- {
- [TestClass]
- public class SessionTest_Connected_ServerSendsDisconnectMessage : SessionTest_ConnectedBase
- {
- private byte[] _packet;
- private DisconnectMessage _disconnectMessage;
- protected override void SetupData()
- {
- base.SetupData();
- _disconnectMessage = new DisconnectMessage(DisconnectReason.ServiceNotAvailable, "Not today!");
- _packet = _disconnectMessage.GetPacket(8, null);
- }
- protected override void Act()
- {
- _ = ServerSocket.Send(_packet, 4, _packet.Length - 4, SocketFlags.None);
- // give session some time to process packet
- Thread.Sleep(200);
- }
- [TestMethod]
- public void IsConnectedShouldReturnFalse()
- {
- Assert.IsFalse(Session.IsConnected);
- }
- [TestMethod]
- public void DisconnectShouldFinishImmediately()
- {
- var stopwatch = new Stopwatch();
- stopwatch.Start();
- Session.Disconnect();
- stopwatch.Stop();
- Assert.IsTrue(stopwatch.ElapsedMilliseconds < 500);
- }
- [TestMethod]
- public void DisconnectedIsRaisedOnce()
- {
- Assert.AreEqual(1, DisconnectedRegister.Count);
- }
- [TestMethod]
- public void DisconnectReceivedIsRaisedOnce()
- {
- Assert.AreEqual(1, DisconnectReceivedRegister.Count);
- var disconnectMessage = DisconnectReceivedRegister[0].Message;
- Assert.IsNotNull(disconnectMessage);
- Assert.AreEqual(_disconnectMessage.Description, disconnectMessage.Description);
- Assert.AreEqual("en", disconnectMessage.Language);
- Assert.AreEqual(_disconnectMessage.ReasonCode, disconnectMessage.ReasonCode);
- }
- [TestMethod]
- public void ErrorOccurredIsNeverRaised()
- {
- Assert.AreEqual(0, ErrorOccurredRegister.Count, ErrorOccurredRegister.AsString());
- }
- [TestMethod]
- public void DisposeShouldFinishImmediately()
- {
- var stopwatch = new Stopwatch();
- stopwatch.Start();
- Session.Dispose();
- stopwatch.Stop();
- Assert.IsTrue(stopwatch.ElapsedMilliseconds < 500);
- }
- [TestMethod]
- public void ReceiveOnServerSocketShouldReturnZero()
- {
- var buffer = new byte[1];
- var actual = ServerSocket.Receive(buffer, 0, buffer.Length, SocketFlags.None);
- Assert.AreEqual(0, actual);
- }
- [TestMethod]
- public void SendMessageShouldThrowSshConnectionException()
- {
- try
- {
- Session.SendMessage(new IgnoreMessage());
- Assert.Fail();
- }
- catch (SshConnectionException ex)
- {
- Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
- Assert.IsNull(ex.InnerException);
- Assert.AreEqual("Client not connected.", ex.Message);
- }
- }
- [TestMethod]
- public void ISession_MessageListenerCompletedShouldBeSignaled()
- {
- var session = (ISession) Session;
- Assert.IsNotNull(session.MessageListenerCompleted);
- Assert.IsTrue(session.MessageListenerCompleted.WaitOne());
- }
- [TestMethod]
- public void ISession_SendMessageShouldThrowSshConnectionException()
- {
- var session = (ISession) Session;
- try
- {
- session.SendMessage(new IgnoreMessage());
- Assert.Fail();
- }
- catch (SshConnectionException ex)
- {
- Assert.AreEqual(DisconnectReason.None, ex.DisconnectReason);
- Assert.IsNull(ex.InnerException);
- Assert.AreEqual("Client not connected.", ex.Message);
- }
- }
- [TestMethod]
- public void ISession_TrySendMessageShouldReturnFalse()
- {
- var session = (ISession) Session;
- var actual = session.TrySendMessage(new IgnoreMessage());
- Assert.IsFalse(actual);
- }
- [TestMethod]
- public void ISession_WaitOnHandle_WaitHandle_ShouldThrowSshConnectionExceptionDetailingDisconnectReason()
- {
- var session = (ISession) Session;
- var waitHandle = new ManualResetEvent(false);
- try
- {
- session.WaitOnHandle(waitHandle);
- Assert.Fail();
- }
- catch (SshConnectionException ex)
- {
- Assert.AreEqual(DisconnectReason.ServiceNotAvailable, ex.DisconnectReason);
- Assert.IsNull(ex.InnerException);
- Assert.AreEqual(string.Format(CultureInfo.InvariantCulture,
- "The connection was closed by the server: {0} ({1}).",
- _disconnectMessage.Description,
- _disconnectMessage.ReasonCode),
- ex.Message);
- }
- }
- [TestMethod]
- public void ISession_WaitOnHandle_WaitHandleAndTimeout_ShouldThrowSshConnectionExceptionDetailingDisconnectReason()
- {
- var session = (ISession) Session;
- var waitHandle = new ManualResetEvent(false);
- try
- {
- session.WaitOnHandle(waitHandle, Session.InfiniteTimeSpan);
- Assert.Fail();
- }
- catch (SshConnectionException ex)
- {
- Assert.AreEqual(DisconnectReason.ServiceNotAvailable, ex.DisconnectReason);
- Assert.IsNull(ex.InnerException);
- Assert.AreEqual(string.Format(CultureInfo.InvariantCulture,
- "The connection was closed by the server: {0} ({1}).",
- _disconnectMessage.Description,
- _disconnectMessage.ReasonCode),
- ex.Message);
- }
- }
- [TestMethod]
- public void ISession_TryWait_WaitHandleAndTimeout_ShouldReturnDisconnected()
- {
- var session = (ISession) Session;
- var waitHandle = new ManualResetEvent(false);
- var result = session.TryWait(waitHandle, Session.InfiniteTimeSpan);
- Assert.AreEqual(WaitResult.Disconnected, result);
- }
- [TestMethod]
- public void ISession_TryWait_WaitHandleAndTimeoutAndException_ShouldReturnDisconnected()
- {
- var session = (ISession) Session;
- var waitHandle = new ManualResetEvent(false);
- var result = session.TryWait(waitHandle, Session.InfiniteTimeSpan, out var exception);
- Assert.AreEqual(WaitResult.Disconnected, result);
- Assert.IsNull(exception);
- }
- }
- }
|