예제 #1
0
        public async Task MyDisposeAsync()
        {
            if (_disposed)
            {
                throw new ObjectDisposedException("SamClientInfo");
            }
            await ReliableHelperSend.MyDisposeAsync().ConfigureAwait(false);

            await SamHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _disposed = true;
        }
예제 #2
0
 public async Task TestMemoryOverhead()
 {
     const string addressSend = "127.0.0.1";
     const int portSend = 7656;
     const string addressRecv = addressSend;
     const int portRecv = 7656;
     const string i2cpOptions = "";
     var samHelperSend = await SamHelper.CreateInstance(
         new SamHelperSettings()
         {
             SamServerAddress = addressSend,
             SamServerPort = portSend
         }, CancellationToken.None
     ).ConfigureAwait(false);
     var samHelperReceive = await SamHelper.CreateInstance(
         new SamHelperSettings()
         {
             SamServerAddress = addressRecv,
             SamServerPort = portRecv
         }, CancellationToken.None
     ).ConfigureAwait(false);
     var reliableHelperSend = new ReliableSamHelper(
         samHelperSend,
         new ReliableSamHelperSettings()
     );
     var reliableHelperRecv = new ReliableSamHelper(
         samHelperReceive,
         new ReliableSamHelperSettings()
     );
     /**/
     var data = new byte[400000];
     MiscFuncs.GetRandomBytes(data);
     _logger.Trace("Begin Total memory - {0} bytes", GC.GetTotalMemory(true));
     for (int i = 0; i < 10; i++)
     {
         var waitRecvMessage = reliableHelperRecv.ReliableMessageReceived
             .Where(x => x.Destination == samHelperSend.Session.Destination)
             .FirstAsync()
             .ToTask();
         try
         {
             var messageId = await reliableHelperSend.SendReliableMessage(
                 samHelperReceive.Session.Destination,
                 data
             ).ConfigureAwait(false);
             _logger.Trace("Message sent id {0}", messageId);
         }
         catch (EnumException<ReliableSamHelper.SendReliableMessageExcs> exc)
         {
             _logger.Trace("Send error {0}", exc.ExceptionCode);
             throw;
         }
         try
         {
             var receivedMessage = await waitRecvMessage.ConfigureAwait(false);
             _logger.Trace(
                 "Message received {0} bytes", 
                 receivedMessage.Data.Length
             );
             Assert.Equal(data, receivedMessage.Data);
         }
         catch (OperationCanceledException exc)
         {
             _logger.Trace("Recv timeout {0}", exc);
             throw;
         }
         catch (Exception exc)
         {
             _logger.Trace("Recv error {0}", exc);
             throw;
         }
     }
     /**/
     long memory = GC.GetTotalMemory(true);
     _logger.Trace("End Total memory - {0} bytes", memory);
     await reliableHelperSend.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("reliableHelperSend disposed");
     await reliableHelperRecv.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("reliableHelperRecv disposed");
     await samHelperSend.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("samHelperSend disposed");
     await samHelperReceive.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("samHelperReceive disposed");
 }
예제 #3
0
 public async Task TestSendReceiveOneMessageImpl()
 {
     const string addressSend = "192.168.56.102";//"192.168.1.132";
     const int portSend = 7656;
     const string addressRecv = addressSend; //"127.0.0.1";
     const int portRecv = 7656;
     var samHelperSend = await SamHelper.CreateInstance(
         new SamHelperSettings()
         {
             SamServerAddress = addressSend,
             SamServerPort = portSend
         }, CancellationToken.None
     ).ConfigureAwait(false);
     var samHelperReceive = await SamHelper.CreateInstance(
         new SamHelperSettings()
         {
             SamServerAddress = addressRecv,
             SamServerPort = portRecv
         }, CancellationToken.None
     ).ConfigureAwait(false);
     var reliableHelperSend = new ReliableSamHelper(
         samHelperSend, 
         new ReliableSamHelperSettings()
     );
     var reliableHelperRecv = new ReliableSamHelper(
         samHelperReceive, 
         new ReliableSamHelperSettings()
     );
     var data = new byte[1];
     MiscFuncs.GetRandomBytes(data);
     var waitRecvMessage = reliableHelperRecv.ReliableMessageReceived
         .Where(x => x.Destination == samHelperSend.Session.Destination)
         .FirstAsync()
         .ToTask();
     var sendProgress = new Progress<OutMessageProgressInfo>(
         x => _logger.Trace(x.ToString())
     );
     try
     {
         var messageId = await reliableHelperSend.SendReliableMessage(
             samHelperReceive.Session.Destination,
             data,
             sendProgress
         ).ConfigureAwait(false);
         _logger.Trace("Message sent id {0}", messageId);
     }
     catch (EnumException<ReliableSamHelper.SendReliableMessageExcs> exc)
     {
         _logger.Trace("Send error {0}", exc.ExceptionCode);
         throw;
     }
     try
     {
         var receivedMessage = await waitRecvMessage.ConfigureAwait(false);
         _logger.Trace("Message received {0} bytes", receivedMessage.Data.Length);
         Assert.Equal(data,receivedMessage.Data);
     }
     catch (OperationCanceledException exc)
     {
         _logger.Trace("Recv timeout {0}", exc);
         throw;
     }
     catch (Exception exc)
     {
         _logger.Trace("Recv error {0}", exc);
         throw;
     }
     _logger.Trace("End Total memory - {0} bytes", GC.GetTotalMemory(true));
     await reliableHelperSend.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("reliableHelperSend disposed");
     await reliableHelperRecv.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("reliableHelperRecv disposed");
     await samHelperSend.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("samHelperSend disposed");
     await samHelperReceive.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("samHelperReceive disposed");
 }
 public async Task TestReconnectingReliable()
 {
     const string addressSend = "127.0.0.1";
     const int portSend = 7656;
     /**/
     var proxyHostname = "127.0.0.1";
     var proxyPort = 17000;
     var proxyServer = await MyTcpProxyServer.CreateInstance(
         new MyTcpProxyServerSettings()
         {
             DestinationHostname = addressSend,
             DestinationPort = portSend,
             ServerHostname = proxyHostname,
             ServerPort = proxyPort
         }
     ).ConfigureAwait(false);
     /**/
     const string addressRecv = addressSend;
     const int portRecv = portSend;
     string sendPrivKeys;
     /**/
     {
         var samHelperSend = await SamHelper.CreateInstance(
             new SamHelperSettings()
             {
                 SamServerAddress = addressSend,
                 SamServerPort = portSend
             }, CancellationToken.None
             ).ConfigureAwait(false);
         sendPrivKeys = samHelperSend.Session.PrivateKey;
         await samHelperSend.MyDisposeAsync().ConfigureAwait(false);
     }
     /**/
     var reconnectingSamHelperSend = await ReconnectingSamHelper.CreateInstance(
         new ReconnectingSamHelperSettings()
         {
             ImplementationHelperSettings =
                 new SamHelperSettings()
                 {
                     SamServerAddress = proxyHostname,
                     SamServerPort = proxyPort,
                     SessionPrivateKeys = sendPrivKeys
                 }
         }, CancellationToken.None
         ).ConfigureAwait(false);
     var samHelperReceive = await SamHelper.CreateInstance(
         new SamHelperSettings()
         {
             SamServerAddress = addressRecv,
             SamServerPort = portRecv
         }, CancellationToken.None
         ).ConfigureAwait(false);
     var reliableHelperSend = new ReliableSamHelper(
         reconnectingSamHelperSend,
         new ReliableSamHelperSettings()
         );
     var reliableHelperRecv = new ReliableSamHelper(
         samHelperReceive,
         new ReliableSamHelperSettings()
         );
     var data = new byte[200000];
     MiscFuncs.GetRandomBytes(data);
     /**/
     await testSendReceiveFunc(
         reliableHelperRecv,
         reconnectingSamHelperSend,
         reliableHelperSend,
         data,
         samHelperReceive
     ).ConfigureAwait(false);
     await proxyServer.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("###################################");
     await Assert.ThrowsAsync<TimeoutException>(
         async () => await testSendReceiveFunc(
             reliableHelperRecv,
             reconnectingSamHelperSend,
             reliableHelperSend,
             data,
             samHelperReceive
         ).ConfigureAwait(false)
     ).ConfigureAwait(false);
     /**/
     _logger.Trace("###################################");
     proxyServer = await MyTcpProxyServer.CreateInstance(
         new MyTcpProxyServerSettings()
         {
             DestinationHostname = addressSend,
             DestinationPort = portSend,
             ServerHostname = proxyHostname,
             ServerPort = proxyPort
         }
     ).ConfigureAwait(false);
     reconnectingSamHelperSend.TryToReconnect(DateTime.UtcNow);
     await Task.Delay(TimeSpan.FromSeconds(15.0d)).ConfigureAwait(false);
     /**/
     await testSendReceiveFunc(
         reliableHelperRecv,
         reconnectingSamHelperSend,
         reliableHelperSend,
         data,
         samHelperReceive
     ).ConfigureAwait(false);
     /**/
     await reliableHelperSend.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("reliableHelperSend disposed");
     await reliableHelperRecv.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("reliableHelperRecv disposed");
     await reconnectingSamHelperSend.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("samHelperSend disposed");
     await samHelperReceive.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("samHelperReceive disposed");
     await proxyServer.MyDisposeAsync().ConfigureAwait(false);
     _logger.Trace("{0} disposed",MyNameof.GetLocalVarName(() => proxyServer));
 }
예제 #5
0
        public async Task TestReconnectingReliable()
        {
            const string addressSend = "127.0.0.1";
            const int    portSend    = 7656;
            /**/
            var proxyHostname = "127.0.0.1";
            var proxyPort     = 17000;
            var proxyServer   = await MyTcpProxyServer.CreateInstance(
                new MyTcpProxyServerSettings()
            {
                DestinationHostname = addressSend,
                DestinationPort     = portSend,
                ServerHostname      = proxyHostname,
                ServerPort          = proxyPort
            }
                ).ConfigureAwait(false);

            /**/
            const string addressRecv = addressSend;
            const int    portRecv    = portSend;
            string       sendPrivKeys;
            /**/
            {
                var samHelperSend = await SamHelper.CreateInstance(
                    new SamHelperSettings()
                {
                    SamServerAddress = addressSend,
                    SamServerPort    = portSend
                }, CancellationToken.None
                    ).ConfigureAwait(false);

                sendPrivKeys = samHelperSend.Session.PrivateKey;
                await samHelperSend.MyDisposeAsync().ConfigureAwait(false);
            }
            /**/
            var reconnectingSamHelperSend = await ReconnectingSamHelper.CreateInstance(
                new ReconnectingSamHelperSettings()
            {
                ImplementationHelperSettings =
                    new SamHelperSettings()
                {
                    SamServerAddress   = proxyHostname,
                    SamServerPort      = proxyPort,
                    SessionPrivateKeys = sendPrivKeys
                }
            }, CancellationToken.None
                ).ConfigureAwait(false);

            var samHelperReceive = await SamHelper.CreateInstance(
                new SamHelperSettings()
            {
                SamServerAddress = addressRecv,
                SamServerPort    = portRecv
            }, CancellationToken.None
                ).ConfigureAwait(false);

            var reliableHelperSend = new ReliableSamHelper(
                reconnectingSamHelperSend,
                new ReliableSamHelperSettings()
                );
            var reliableHelperRecv = new ReliableSamHelper(
                samHelperReceive,
                new ReliableSamHelperSettings()
                );
            var data = new byte[200000];

            MiscFuncs.GetRandomBytes(data);
            /**/
            await testSendReceiveFunc(
                reliableHelperRecv,
                reconnectingSamHelperSend,
                reliableHelperSend,
                data,
                samHelperReceive
                ).ConfigureAwait(false);

            await proxyServer.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("###################################");
            await Assert.ThrowsAsync <TimeoutException>(
                async() => await testSendReceiveFunc(
                    reliableHelperRecv,
                    reconnectingSamHelperSend,
                    reliableHelperSend,
                    data,
                    samHelperReceive
                    ).ConfigureAwait(false)
                ).ConfigureAwait(false);

            /**/
            _logger.Trace("###################################");
            proxyServer = await MyTcpProxyServer.CreateInstance(
                new MyTcpProxyServerSettings()
            {
                DestinationHostname = addressSend,
                DestinationPort     = portSend,
                ServerHostname      = proxyHostname,
                ServerPort          = proxyPort
            }
                ).ConfigureAwait(false);

            reconnectingSamHelperSend.TryToReconnect(DateTime.UtcNow);
            await Task.Delay(TimeSpan.FromSeconds(15.0d)).ConfigureAwait(false);

            /**/
            await testSendReceiveFunc(
                reliableHelperRecv,
                reconnectingSamHelperSend,
                reliableHelperSend,
                data,
                samHelperReceive
                ).ConfigureAwait(false);

            /**/
            await reliableHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("reliableHelperSend disposed");
            await reliableHelperRecv.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("reliableHelperRecv disposed");
            await reconnectingSamHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("samHelperSend disposed");
            await samHelperReceive.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("samHelperReceive disposed");
            await proxyServer.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("{0} disposed", MyNameof.GetLocalVarName(() => proxyServer));
        }
예제 #6
0
        public async Task TestMemoryOverhead()
        {
            const string addressSend   = "127.0.0.1";
            const int    portSend      = 7656;
            const string addressRecv   = addressSend;
            const int    portRecv      = 7656;
            const string i2cpOptions   = "";
            var          samHelperSend = await SamHelper.CreateInstance(
                new SamHelperSettings()
            {
                SamServerAddress = addressSend,
                SamServerPort    = portSend
            }, CancellationToken.None
                ).ConfigureAwait(false);

            var samHelperReceive = await SamHelper.CreateInstance(
                new SamHelperSettings()
            {
                SamServerAddress = addressRecv,
                SamServerPort    = portRecv
            }, CancellationToken.None
                ).ConfigureAwait(false);

            var reliableHelperSend = new ReliableSamHelper(
                samHelperSend,
                new ReliableSamHelperSettings()
                );
            var reliableHelperRecv = new ReliableSamHelper(
                samHelperReceive,
                new ReliableSamHelperSettings()
                );
            /**/
            var data = new byte[400000];

            MiscFuncs.GetRandomBytes(data);
            _logger.Trace("Begin Total memory - {0} bytes", GC.GetTotalMemory(true));
            for (int i = 0; i < 10; i++)
            {
                var waitRecvMessage = reliableHelperRecv.ReliableMessageReceived
                                      .Where(x => x.Destination == samHelperSend.Session.Destination)
                                      .FirstAsync()
                                      .ToTask();
                try
                {
                    var messageId = await reliableHelperSend.SendReliableMessage(
                        samHelperReceive.Session.Destination,
                        data
                        ).ConfigureAwait(false);

                    _logger.Trace("Message sent id {0}", messageId);
                }
                catch (EnumException <ReliableSamHelper.SendReliableMessageExcs> exc)
                {
                    _logger.Trace("Send error {0}", exc.ExceptionCode);
                    throw;
                }
                try
                {
                    var receivedMessage = await waitRecvMessage.ConfigureAwait(false);

                    _logger.Trace(
                        "Message received {0} bytes",
                        receivedMessage.Data.Length
                        );
                    Assert.Equal(data, receivedMessage.Data);
                }
                catch (OperationCanceledException exc)
                {
                    _logger.Trace("Recv timeout {0}", exc);
                    throw;
                }
                catch (Exception exc)
                {
                    _logger.Trace("Recv error {0}", exc);
                    throw;
                }
            }
            /**/
            long memory = GC.GetTotalMemory(true);

            _logger.Trace("End Total memory - {0} bytes", memory);
            await reliableHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("reliableHelperSend disposed");
            await reliableHelperRecv.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("reliableHelperRecv disposed");
            await samHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("samHelperSend disposed");
            await samHelperReceive.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("samHelperReceive disposed");
        }
예제 #7
0
        public async Task TestSendReceiveOneMessageImpl()
        {
            const string addressSend   = "192.168.56.102"; //"192.168.1.132";
            const int    portSend      = 7656;
            const string addressRecv   = addressSend;      //"127.0.0.1";
            const int    portRecv      = 7656;
            var          samHelperSend = await SamHelper.CreateInstance(
                new SamHelperSettings()
            {
                SamServerAddress = addressSend,
                SamServerPort    = portSend
            }, CancellationToken.None
                ).ConfigureAwait(false);

            var samHelperReceive = await SamHelper.CreateInstance(
                new SamHelperSettings()
            {
                SamServerAddress = addressRecv,
                SamServerPort    = portRecv
            }, CancellationToken.None
                ).ConfigureAwait(false);

            var reliableHelperSend = new ReliableSamHelper(
                samHelperSend,
                new ReliableSamHelperSettings()
                );
            var reliableHelperRecv = new ReliableSamHelper(
                samHelperReceive,
                new ReliableSamHelperSettings()
                );
            var data = new byte[1];

            MiscFuncs.GetRandomBytes(data);
            var waitRecvMessage = reliableHelperRecv.ReliableMessageReceived
                                  .Where(x => x.Destination == samHelperSend.Session.Destination)
                                  .FirstAsync()
                                  .ToTask();
            var sendProgress = new Progress <OutMessageProgressInfo>(
                x => _logger.Trace(x.ToString())
                );

            try
            {
                var messageId = await reliableHelperSend.SendReliableMessage(
                    samHelperReceive.Session.Destination,
                    data,
                    sendProgress
                    ).ConfigureAwait(false);

                _logger.Trace("Message sent id {0}", messageId);
            }
            catch (EnumException <ReliableSamHelper.SendReliableMessageExcs> exc)
            {
                _logger.Trace("Send error {0}", exc.ExceptionCode);
                throw;
            }
            try
            {
                var receivedMessage = await waitRecvMessage.ConfigureAwait(false);

                _logger.Trace("Message received {0} bytes", receivedMessage.Data.Length);
                Assert.Equal(data, receivedMessage.Data);
            }
            catch (OperationCanceledException exc)
            {
                _logger.Trace("Recv timeout {0}", exc);
                throw;
            }
            catch (Exception exc)
            {
                _logger.Trace("Recv error {0}", exc);
                throw;
            }
            _logger.Trace("End Total memory - {0} bytes", GC.GetTotalMemory(true));
            await reliableHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("reliableHelperSend disposed");
            await reliableHelperRecv.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("reliableHelperRecv disposed");
            await samHelperSend.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("samHelperSend disposed");
            await samHelperReceive.MyDisposeAsync().ConfigureAwait(false);

            _logger.Trace("samHelperReceive disposed");
        }