| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- using System;
- using System.Collections.Generic;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- using Renci.SshNet.Common;
- using Renci.SshNet.Messages;
- using Renci.SshNet.Messages.Connection;
- namespace Renci.SshNet.Tests.Classes.Channels
- {
- [TestClass]
- public class ChannelTest_OnSessionChannelRequestReceived_HandleUnknownMessage : ChannelTestBase
- {
- private uint _localWindowSize;
- private uint _localPacketSize;
- private uint _localChannelNumber;
- private uint _remoteChannelNumber;
- private uint _remoteWindowSize;
- private uint _remotePacketSize;
- private ChannelStub _channel;
- private IList<ExceptionEventArgs> _channelExceptionRegister;
- private UnknownRequestInfoWithWantReply _requestInfo;
- protected override void SetupData()
- {
- var random = new Random();
- _localWindowSize = (uint)random.Next(1000, int.MaxValue);
- _localPacketSize = _localWindowSize - 1;
- _localChannelNumber = (uint)random.Next(0, int.MaxValue);
- _remoteChannelNumber = (uint)random.Next(0, int.MaxValue);
- _remoteWindowSize = (uint)random.Next(0, int.MaxValue);
- _remotePacketSize = (uint)random.Next(0, int.MaxValue);
- _channelExceptionRegister = new List<ExceptionEventArgs>();
- _requestInfo = new UnknownRequestInfoWithWantReply();
- }
- protected override void SetupMocks()
- {
- _ = SessionMock.Setup(p => p.ConnectionInfo)
- .Returns(new ConnectionInfo("host", "user", new PasswordAuthenticationMethod("user", "password")));
- _ = SessionMock.Setup(p => p.SendMessage(It.IsAny<Message>()));
- }
- protected override void Arrange()
- {
- base.Arrange();
- _channel = new ChannelStub(SessionMock.Object, _localChannelNumber, _localWindowSize, _localPacketSize);
- _channel.InitializeRemoteChannelInfo(_remoteChannelNumber, _remoteWindowSize, _remotePacketSize);
- _channel.SetIsOpen(true);
- _channel.Exception += (sender, args) => _channelExceptionRegister.Add(args);
- }
- protected override void Act()
- {
- SessionMock.Raise(s => s.ChannelRequestReceived += null,
- new MessageEventArgs<ChannelRequestMessage>(new ChannelRequestMessage(_localChannelNumber, _requestInfo)));
- }
- [TestMethod]
- public void FailureMessageWasSent()
- {
- SessionMock.Verify(p => p.SendMessage(It.Is<ChannelFailureMessage>(m => m.LocalChannelNumber == _channel.RemoteChannelNumber)), Times.Once);
- }
- [TestMethod]
- public void NoExceptionShouldHaveFired()
- {
- Assert.AreEqual(0, _channelExceptionRegister.Count);
- }
- }
- internal class UnknownRequestInfoWithWantReply : RequestInfo
- {
- public override string RequestName
- {
- get
- {
- return nameof(UnknownRequestInfoWithWantReply);
- }
- }
- internal UnknownRequestInfoWithWantReply()
- {
- WantReply = true;
- }
- }
- }
|