130 lines
3.1 KiB
C#
Raw Normal View History

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
}
}