| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 | using System;using System.Collections.Generic;using System.Diagnostics;using System.Net;using System.Net.Sockets;using Microsoft.VisualStudio.TestTools.UnitTesting;using Moq;using Renci.SshNet.Common;using Renci.SshNet.Tests.Common;namespace Renci.SshNet.Tests.Classes.Connection{    [TestClass]    public class Socks5ConnectorTest_Connect_TimeoutConnectionReply : Socks5ConnectorTestBase    {        private ConnectionInfo _connectionInfo;        private Exception _actualException;        private AsyncSocketListener _proxyServer;        private Socket _clientSocket;        private List<byte> _bytesReceivedByProxy;        private Stopwatch _stopWatch;        protected override void SetupData()        {            base.SetupData();            var random = new Random();            _connectionInfo = CreateConnectionInfo("proxyUser", "proxyPwd");            _connectionInfo.Timeout = TimeSpan.FromMilliseconds(random.Next(50, 200));            _stopWatch = new Stopwatch();            _bytesReceivedByProxy = new List<byte>();            _clientSocket = SocketFactory.Create(SocketType.Stream, ProtocolType.Tcp);            _proxyServer = new AsyncSocketListener(new IPEndPoint(IPAddress.Loopback, _connectionInfo.ProxyPort));            _proxyServer.BytesReceived += (bytesReceived, socket) =>            {                _bytesReceivedByProxy.AddRange(bytesReceived);                if (_bytesReceivedByProxy.Count == 4)                {                    _ = socket.Send(new byte[]                        {                                    // SOCKS version                                    0x05,                                    // Require no authentication                                    0x00                        });                }            };            _proxyServer.Start();        }        protected override void SetupMocks()        {            _ = SocketFactoryMock.Setup(p => p.Create(SocketType.Stream, ProtocolType.Tcp))                                 .Returns(_clientSocket);        }        protected override void TearDown()        {            base.TearDown();            _proxyServer?.Dispose();            _clientSocket?.Dispose();        }        protected override void Act()        {            _stopWatch.Start();            try            {                _ = Connector.Connect(_connectionInfo);                Assert.Fail();            }            catch (SocketException ex)            {                _actualException = ex;            }            catch (SshOperationTimeoutException ex)            {                _actualException = ex;            }            finally            {                _stopWatch.Stop();            }        }        [TestMethod]        public void ConnectShouldHaveThrownSshOperationTimeoutException()        {            Assert.IsNull(_actualException.InnerException);            Assert.IsInstanceOfType<SshOperationTimeoutException>(_actualException);        }        [TestMethod]        public void ConnectShouldHaveRespectedTimeout()        {            var errorText = string.Format("Elapsed: {0}, Timeout: {1}",                                          _stopWatch.ElapsedMilliseconds,                                          _connectionInfo.Timeout.TotalMilliseconds);            // Compare elapsed time with configured timeout, allowing for a margin of error            Assert.IsTrue(_stopWatch.ElapsedMilliseconds >= _connectionInfo.Timeout.TotalMilliseconds - 10, errorText);            Assert.IsTrue(_stopWatch.ElapsedMilliseconds < _connectionInfo.Timeout.TotalMilliseconds + 100, errorText);        }        [TestMethod]        public void CreateOnSocketFactoryShouldHaveBeenInvokedOnce()        {            SocketFactoryMock.Verify(p => p.Create(SocketType.Stream, ProtocolType.Tcp),                                     Times.Once());        }    }}
 |