From 503d8964eaa3ae015aaedd1ef980f389c496fc56 Mon Sep 17 00:00:00 2001 From: Garry Newman Date: Tue, 7 May 2019 17:42:03 +0100 Subject: [PATCH] NormalEndtoEnd test, fixed lockups --- .../NetworkingSockets.cs | 44 +++++++++++++++++-- 1 file changed, 41 insertions(+), 3 deletions(-) diff --git a/Facepunch.Steamworks.Test/NetworkingSockets.cs b/Facepunch.Steamworks.Test/NetworkingSockets.cs index ab8f435..9aebd53 100644 --- a/Facepunch.Steamworks.Test/NetworkingSockets.cs +++ b/Facepunch.Steamworks.Test/NetworkingSockets.cs @@ -54,6 +54,20 @@ namespace Steamworks await Task.WhenAll( server, client ); } + [TestMethod] + public async Task NormalEndtoEnd() + { + var socket = SteamNetworkingSockets.CreateNormalSocket( NetAddress.AnyIp( 12445 ) ); + var server = socket.RunAsync(); + + await Task.Delay( 1000 ); + + var connection = SteamNetworkingSockets.ConnectNormal( NetAddress.From( System.Net.IPAddress.Parse( "127.0.0.1" ), 12445 ) ); + var client = connection.RunAsync(); + + await Task.WhenAll( server, client ); + } + private class TestConnectionInterface : ConnectionInterface { public override void OnConnectionChanged( ConnectionInfo data ) @@ -91,13 +105,27 @@ namespace Steamworks { Console.WriteLine( "[Connection] RunAsync" ); - while ( !Connected ) + var sw = System.Diagnostics.Stopwatch.StartNew(); + + while ( Connecting ) + { await Task.Delay( 10 ); + if ( sw.Elapsed.TotalSeconds > 30 ) + break; + } + + if ( !Connected ) + { + Console.WriteLine( "[Connection] Couldn't connect!" ); + Console.WriteLine( Connection.DetailedStatus() ); + return; + } + Console.WriteLine( "[Connection] Hey We're Connected!" ); - var sw = System.Diagnostics.Stopwatch.StartNew(); + sw = System.Diagnostics.Stopwatch.StartNew(); while ( Connected ) { Receive(); @@ -186,9 +214,19 @@ namespace Steamworks internal async Task RunAsync() { + var sw = System.Diagnostics.Stopwatch.StartNew(); + while ( Connected.Count == 0 ) + { await Task.Delay( 10 ); + if ( sw.Elapsed.TotalSeconds > 2 ) + { + Assert.Fail( "Client Took Too Long To Connect" ); + break; + } + } + await Task.Delay( 1000 ); var singleClient = Connected.First(); @@ -205,7 +243,7 @@ namespace Steamworks await Task.Delay( 100 ); singleClient.SendMessage( "Hello Client!?" ); - var sw = System.Diagnostics.Stopwatch.StartNew(); + sw = System.Diagnostics.Stopwatch.StartNew(); while ( Connected.Contains( singleClient ) ) {