2016-09-30 15:29:22 +01:00
|
|
|
|
using System;
|
2019-04-15 21:18:03 +01:00
|
|
|
|
using System.Threading.Tasks;
|
2016-09-30 15:29:22 +01:00
|
|
|
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
2019-04-15 21:18:03 +01:00
|
|
|
|
|
|
|
|
|
namespace Steamworks
|
2016-09-30 15:29:22 +01:00
|
|
|
|
{
|
2016-10-25 10:29:35 +01:00
|
|
|
|
[DeploymentItem( "steam_api64.dll" )]
|
2016-10-26 16:10:20 +01:00
|
|
|
|
[DeploymentItem( "tier0_s64.dll" )]
|
|
|
|
|
[DeploymentItem( "vstdlib_s64.dll" )]
|
|
|
|
|
[DeploymentItem( "steamclient64.dll" )]
|
2016-09-30 15:29:22 +01:00
|
|
|
|
[TestClass]
|
2019-04-15 21:18:03 +01:00
|
|
|
|
public partial class GameServerTest
|
2016-09-30 15:29:22 +01:00
|
|
|
|
{
|
|
|
|
|
[TestMethod]
|
|
|
|
|
public void Init()
|
|
|
|
|
{
|
2019-04-16 14:21:48 +01:00
|
|
|
|
SteamServer.DedicatedServer = true;
|
|
|
|
|
SteamServer.DedicatedServer = false;
|
2019-04-15 21:18:03 +01:00
|
|
|
|
}
|
2016-11-03 14:33:03 +00:00
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-04-15 21:18:03 +01:00
|
|
|
|
public async Task PublicIp()
|
2016-11-03 14:33:03 +00:00
|
|
|
|
{
|
2019-04-15 21:18:03 +01:00
|
|
|
|
while ( true )
|
2016-11-03 14:33:03 +00:00
|
|
|
|
{
|
2019-04-16 14:21:48 +01:00
|
|
|
|
var ip = SteamServer.PublicIp;
|
2016-11-03 14:33:03 +00:00
|
|
|
|
|
2019-04-15 21:18:03 +01:00
|
|
|
|
if ( ip == null )
|
2016-11-03 14:33:03 +00:00
|
|
|
|
{
|
2019-04-15 21:18:03 +01:00
|
|
|
|
await Task.Delay( 10 );
|
|
|
|
|
continue;
|
2016-11-03 14:33:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-04-15 21:18:03 +01:00
|
|
|
|
Assert.IsNotNull( ip );
|
|
|
|
|
Console.WriteLine( ip.ToString() );
|
|
|
|
|
break;
|
2016-11-03 14:33:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2016-10-03 12:06:30 +01:00
|
|
|
|
|
|
|
|
|
[TestMethod]
|
2019-04-15 21:39:13 +01:00
|
|
|
|
public async Task BeginAuthSession()
|
2016-10-03 12:06:30 +01:00
|
|
|
|
{
|
2019-04-16 11:45:44 +01:00
|
|
|
|
var stopwatch = System.Diagnostics.Stopwatch.StartNew();
|
2019-04-15 21:39:13 +01:00
|
|
|
|
bool finished = false;
|
2019-04-16 15:25:35 +01:00
|
|
|
|
string failed = null;
|
2019-04-16 12:17:24 +01:00
|
|
|
|
AuthResponse response = AuthResponse.AuthTicketInvalidAlreadyUsed;
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Clientside calls this function, gets ticket
|
|
|
|
|
//
|
2019-04-16 14:21:48 +01:00
|
|
|
|
var clientTicket = SteamUser.GetAuthSessionTicket();
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// The client sends this data to the server along with their steamid
|
|
|
|
|
//
|
|
|
|
|
var ticketData = clientTicket.Data;
|
2019-04-16 14:26:42 +01:00
|
|
|
|
var clientSteamId = SteamClient.SteamId;
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Server listens to auth responses from Gabe
|
|
|
|
|
//
|
2019-04-16 14:21:48 +01:00
|
|
|
|
SteamServer.OnValidateAuthTicketResponse += ( steamid, ownerid, rsponse ) =>
|
2019-04-15 21:39:13 +01:00
|
|
|
|
{
|
|
|
|
|
finished = true;
|
|
|
|
|
response = rsponse;
|
|
|
|
|
|
2019-04-16 15:25:35 +01:00
|
|
|
|
if ( steamid == 0 )
|
|
|
|
|
failed = $"steamid is 0! {steamid} != {ownerid} ({rsponse})";
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
2019-04-16 15:25:35 +01:00
|
|
|
|
if ( ownerid == 0 )
|
|
|
|
|
failed = $"ownerid is 0! {steamid} != {ownerid} ({rsponse})";
|
|
|
|
|
|
|
|
|
|
if ( steamid != ownerid )
|
|
|
|
|
failed = $"Steamid and Ownerid are different! {steamid} != {ownerid} ({rsponse})";
|
2019-04-15 21:39:13 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Server gets the ticket, starts authing
|
|
|
|
|
//
|
2019-04-16 14:21:48 +01:00
|
|
|
|
if ( !SteamServer.BeginAuthSession( ticketData, clientSteamId ) )
|
2019-04-15 21:39:13 +01:00
|
|
|
|
{
|
|
|
|
|
Assert.Fail( "BeginAuthSession returned false, called bullshit without even having to check with Gabe" );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Wait for that to go through steam
|
|
|
|
|
//
|
|
|
|
|
while ( !finished )
|
2019-04-16 11:45:44 +01:00
|
|
|
|
{
|
|
|
|
|
if ( stopwatch.Elapsed.TotalSeconds > 5 )
|
|
|
|
|
throw new System.Exception( "Took too long waiting for AuthSessionResponse.OK" );
|
|
|
|
|
|
2019-04-15 21:39:13 +01:00
|
|
|
|
await Task.Delay( 10 );
|
2019-04-16 11:45:44 +01:00
|
|
|
|
}
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
2019-04-16 12:17:24 +01:00
|
|
|
|
Assert.AreEqual( response, AuthResponse.OK );
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
2019-04-16 15:25:35 +01:00
|
|
|
|
if ( failed != null )
|
|
|
|
|
Assert.Fail( failed );
|
|
|
|
|
|
2019-04-15 21:39:13 +01:00
|
|
|
|
finished = false;
|
2019-04-16 11:45:44 +01:00
|
|
|
|
stopwatch = System.Diagnostics.Stopwatch.StartNew();
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// The client is leaving, and now wants to cancel the ticket
|
|
|
|
|
//
|
|
|
|
|
|
2019-04-16 11:45:44 +01:00
|
|
|
|
Assert.AreNotEqual( 0, clientTicket.Handle );
|
2019-04-15 21:39:13 +01:00
|
|
|
|
clientTicket.Cancel();
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// We should get another callback
|
|
|
|
|
//
|
|
|
|
|
while ( !finished )
|
2019-04-16 11:45:44 +01:00
|
|
|
|
{
|
|
|
|
|
if ( stopwatch.Elapsed.TotalSeconds > 5 )
|
|
|
|
|
throw new System.Exception( "Took too long waiting for AuthSessionResponse.AuthTicketCanceled" );
|
|
|
|
|
|
2019-04-15 21:39:13 +01:00
|
|
|
|
await Task.Delay( 10 );
|
2019-04-16 11:45:44 +01:00
|
|
|
|
}
|
2019-04-15 21:39:13 +01:00
|
|
|
|
|
2019-04-16 15:25:35 +01:00
|
|
|
|
if ( failed != null )
|
|
|
|
|
Assert.Fail( failed );
|
|
|
|
|
|
|
|
|
|
//Assert.AreEqual( response, AuthResponse.AuthTicketCanceled );
|
2016-10-03 15:25:19 +01:00
|
|
|
|
|
2019-04-15 21:39:13 +01:00
|
|
|
|
}
|
2016-09-30 15:29:22 +01:00
|
|
|
|
}
|
|
|
|
|
}
|