| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using Microsoft.Extensions.Logging.Abstractions;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- using Renci.SshNet.Channels;
- using Renci.SshNet.Common;
- using Renci.SshNet.Tests.Common;
- namespace Renci.SshNet.Tests.Classes
- {
- [TestClass]
- public class SubsystemSession_OnChannelException_Connected
- {
- private Mock<ISession> _sessionMock;
- private Mock<IChannelSession> _channelMock;
- private string _subsystemName;
- private SubsystemSessionStub _subsystemSession;
- private int _operationTimeout;
- private IList<EventArgs> _disconnectedRegister;
- private IList<ExceptionEventArgs> _errorOccurredRegister;
- private ExceptionEventArgs _channelExceptionEventArgs;
- private MockSequence _sequence;
- [TestInitialize]
- public void Setup()
- {
- Arrange();
- Act();
- }
- protected void Arrange()
- {
- var random = new Random();
- _subsystemName = random.Next().ToString(CultureInfo.InvariantCulture);
- _operationTimeout = 30000;
- _disconnectedRegister = new List<EventArgs>();
- _errorOccurredRegister = new List<ExceptionEventArgs>();
- _channelExceptionEventArgs = new ExceptionEventArgs(new SystemException());
- _sessionMock = new Mock<ISession>(MockBehavior.Strict);
- _sessionMock.Setup(p => p.SessionLoggerFactory).Returns(NullLoggerFactory.Instance);
- _channelMock = new Mock<IChannelSession>(MockBehavior.Strict);
- _sequence = new MockSequence();
- _sessionMock.InSequence(_sequence).Setup(p => p.CreateChannelSession()).Returns(_channelMock.Object);
- _channelMock.InSequence(_sequence).Setup(p => p.Open());
- _channelMock.InSequence(_sequence).Setup(p => p.SendSubsystemRequest(_subsystemName)).Returns(true);
- _subsystemSession = new SubsystemSessionStub(
- _sessionMock.Object,
- _subsystemName,
- _operationTimeout);
- _subsystemSession.Disconnected += (sender, args) => _disconnectedRegister.Add(args);
- _subsystemSession.ErrorOccurred += (sender, args) => _errorOccurredRegister.Add(args);
- _subsystemSession.Connect();
- }
- protected void Act()
- {
- _channelMock.Raise(s => s.Exception += null, _channelExceptionEventArgs);
- }
- [TestMethod]
- public void DisconnectHasNeverFired()
- {
- Assert.AreEqual(0, _disconnectedRegister.Count);
- }
- [TestMethod]
- public void ErrorOccurredHasFiredOnce()
- {
- Assert.AreEqual(1, _errorOccurredRegister.Count, _errorOccurredRegister.AsString());
- Assert.AreSame(_channelExceptionEventArgs.Exception, _errorOccurredRegister[0].Exception, _errorOccurredRegister.AsString());
- }
- [TestMethod]
- public void IsOpenShouldReturnTrueWhenChannelIsOpen()
- {
- _channelMock.InSequence(_sequence).Setup(p => p.IsOpen).Returns(true);
- Assert.IsTrue(_subsystemSession.IsOpen);
- _channelMock.Verify(p => p.IsOpen, Times.Exactly(1));
- }
- [TestMethod]
- public void IsOpenShouldReturnFalseWhenChannelIsNotOpen()
- {
- _channelMock.InSequence(_sequence).Setup(p => p.IsOpen).Returns(false);
- Assert.IsFalse(_subsystemSession.IsOpen);
- _channelMock.Verify(p => p.IsOpen, Times.Exactly(1));
- }
- [TestMethod]
- public void DisposeOnChannelShouldNeverBeInvoked()
- {
- _channelMock.Verify(p => p.Dispose(), Times.Never);
- }
- }
- }
|