| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- using Renci.SshNet.Channels;
- using Renci.SshNet.Common;
- namespace Renci.SshNet.Tests.Classes
- {
- [TestClass]
- public class SubsystemSession_OnSessionErrorOccurred_Disposed
- {
- 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 _errorOccurredEventArgs;
- [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>();
- _errorOccurredEventArgs = new ExceptionEventArgs(new SystemException());
- _sessionMock = new Mock<ISession>(MockBehavior.Strict);
- _channelMock = new Mock<IChannelSession>(MockBehavior.Strict);
- var 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);
- _channelMock.InSequence(sequence).Setup(p => p.Dispose());
- _subsystemSession = new SubsystemSessionStub(
- _sessionMock.Object,
- _subsystemName,
- _operationTimeout);
- _subsystemSession.Disconnected += (sender, args) => _disconnectedRegister.Add(args);
- _subsystemSession.ErrorOccurred += (sender, args) => _errorOccurredRegister.Add(args);
- _subsystemSession.Connect();
- _subsystemSession.Dispose();
- }
- protected void Act()
- {
- _sessionMock.Raise(s => s.ErrorOccured += null, _errorOccurredEventArgs);
- }
- [TestMethod]
- public void DisconnectHasNeverFired()
- {
- Assert.AreEqual(0, _disconnectedRegister.Count);
- }
- [TestMethod]
- public void ErrorOccurredHasNeverFired()
- {
- Assert.AreEqual(0, _errorOccurredRegister.Count);
- }
- [TestMethod]
- public void IsOpenShouldReturnFalse()
- {
- Assert.IsFalse(_subsystemSession.IsOpen);
- }
- }
- }
|