| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using System.Net;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- using Renci.SshNet.Channels;
- using Renci.SshNet.Common;
- using Renci.SshNet.Messages.Connection;
- namespace Renci.SshNet.Tests.Classes
- {
- [TestClass]
- public class ForwardedPortRemoteTest_Dispose_PortNeverStarted
- {
- private Mock<ISession> _sessionMock;
- private Mock<IConnectionInfo> _connectionInfoMock;
- private ForwardedPortRemote _forwardedPort;
- private IList<EventArgs> _closingRegister;
- private IList<ExceptionEventArgs> _exceptionRegister;
- private IPEndPoint _bindEndpoint;
- private IPEndPoint _remoteEndpoint;
- [TestInitialize]
- public void Setup()
- {
- Arrange();
- Act();
- }
- [TestCleanup]
- public void Cleanup()
- {
- if (_forwardedPort != null)
- {
- _forwardedPort.Dispose();
- _forwardedPort = null;
- }
- }
- protected void Arrange()
- {
- var random = new Random();
- _closingRegister = new List<EventArgs>();
- _exceptionRegister = new List<ExceptionEventArgs>();
- _bindEndpoint = new IPEndPoint(IPAddress.Any, random.Next(IPEndPoint.MinPort, IPEndPoint.MaxPort));
- _remoteEndpoint = new IPEndPoint(IPAddress.Parse("193.168.1.5"), random.Next(IPEndPoint.MinPort, IPEndPoint.MaxPort));
- _connectionInfoMock = new Mock<IConnectionInfo>(MockBehavior.Strict);
- _sessionMock = new Mock<ISession>(MockBehavior.Strict);
- _connectionInfoMock.Setup(p => p.Timeout).Returns(TimeSpan.FromSeconds(15));
- _sessionMock.Setup(p => p.IsConnected).Returns(true);
- _sessionMock.Setup(p => p.ConnectionInfo).Returns(_connectionInfoMock.Object);
- _forwardedPort = new ForwardedPortRemote(_bindEndpoint.Address, (uint)_bindEndpoint.Port, _remoteEndpoint.Address, (uint)_remoteEndpoint.Port);
- _forwardedPort.Closing += (sender, args) => _closingRegister.Add(args);
- _forwardedPort.Exception += (sender, args) => _exceptionRegister.Add(args);
- _forwardedPort.Session = _sessionMock.Object;
- }
- protected void Act()
- {
- _forwardedPort.Dispose();
- }
- [TestMethod]
- public void IsStartedShouldReturnFalse()
- {
- Assert.IsFalse(_forwardedPort.IsStarted);
- }
- [TestMethod]
- public void ForwardedPortShouldIgnoreChannelOpenMessagesWhenDisposed()
- {
- var channelNumberDisposed = (uint)new Random().Next(1001, int.MaxValue);
- var initialWindowSizeDisposed = (uint)new Random().Next(0, int.MaxValue);
- var maximumPacketSizeDisposed = (uint)new Random().Next(0, int.MaxValue);
- var originatorAddressDisposed = new Random().Next().ToString(CultureInfo.InvariantCulture);
- var originatorPortDisposed = (uint)new Random().Next(0, int.MaxValue);
- var channelMock = new Mock<IChannelForwardedTcpip>(MockBehavior.Strict);
- _sessionMock.Setup(
- p =>
- p.CreateChannelForwardedTcpip(channelNumberDisposed, initialWindowSizeDisposed, maximumPacketSizeDisposed)).Returns(channelMock.Object);
- _sessionMock.Setup(
- p =>
- p.SendMessage(new ChannelOpenFailureMessage(channelNumberDisposed, string.Empty,
- ChannelOpenFailureMessage.AdministrativelyProhibited)));
- _sessionMock.Raise(p => p.ChannelOpenReceived += null, new ChannelOpenMessage(channelNumberDisposed, initialWindowSizeDisposed, maximumPacketSizeDisposed, new ForwardedTcpipChannelInfo(_forwardedPort.BoundHost, _forwardedPort.BoundPort, originatorAddressDisposed, originatorPortDisposed)));
- _sessionMock.Verify(p => p.CreateChannelForwardedTcpip(channelNumberDisposed, initialWindowSizeDisposed, maximumPacketSizeDisposed), Times.Never);
- _sessionMock.Verify(p => p.SendMessage(It.Is<ChannelOpenFailureMessage>(c => c.LocalChannelNumber == channelNumberDisposed && c.ReasonCode == ChannelOpenFailureMessage.AdministrativelyProhibited && c.Description == string.Empty && c.Language == null)), Times.Never);
- }
- [TestMethod]
- public void ClosingShouldNotHaveFired()
- {
- Assert.AreEqual(0, _closingRegister.Count);
- }
- [TestMethod]
- public void ExceptionShouldNotHaveFired()
- {
- Assert.AreEqual(0, _exceptionRegister.Count);
- }
- }
- }
|