mirror of
https://github.com/Facepunch/Facepunch.Steamworks.git
synced 2025-01-24 12:38:00 +03:00
Test fixes
This commit is contained in:
parent
3255135df1
commit
c1d611dae7
@ -14,7 +14,25 @@ namespace Steamworks
|
||||
[AssemblyInitialize]
|
||||
public static void AssemblyInit( TestContext context )
|
||||
{
|
||||
//
|
||||
// Init Client
|
||||
//
|
||||
Steamworks.Steam.Init( 4000 );
|
||||
|
||||
//
|
||||
// Init Server
|
||||
//
|
||||
var serverInit = new ServerInit( "gmod", "Garry Mode" )
|
||||
{
|
||||
GamePort = 28015,
|
||||
Secure = true,
|
||||
QueryPort = 28016
|
||||
};
|
||||
|
||||
Steamworks.GameServer.Init( 4000, serverInit );
|
||||
|
||||
GameServer.LogOnAnonymous();
|
||||
|
||||
}
|
||||
|
||||
static void OnNewUrlLaunchParameters()
|
@ -88,25 +88,25 @@
|
||||
<Reference Include="System" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="Client\AchievementsTest.cs" />
|
||||
<Compile Include="Client\UserTest.cs" />
|
||||
<Compile Include="Client\UtilsTest.cs" />
|
||||
<Compile Include="Client\ClientTest.cs" />
|
||||
<Compile Include="Client\LobbyTest.cs" />
|
||||
<Compile Include="Client\LeaderboardTest.cs" />
|
||||
<Compile Include="Client\AppTest.cs" />
|
||||
<Compile Include="Client\RemoteStorageTest.cs" />
|
||||
<Compile Include="Client\InventoryTest.cs" />
|
||||
<Compile Include="Client\WorkshopTest.cs" />
|
||||
<Compile Include="Client\NetworkingTest.cs" />
|
||||
<Compile Include="AchievementsTest.cs" />
|
||||
<Compile Include="UserTest.cs" />
|
||||
<Compile Include="UtilsTest.cs" />
|
||||
<Compile Include="ClientTest.cs" />
|
||||
<Compile Include="LobbyTest.cs" />
|
||||
<Compile Include="LeaderboardTest.cs" />
|
||||
<Compile Include="AppTest.cs" />
|
||||
<Compile Include="RemoteStorageTest.cs" />
|
||||
<Compile Include="InventoryTest.cs" />
|
||||
<Compile Include="WorkshopTest.cs" />
|
||||
<Compile Include="NetworkingTest.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="Client\FriendsTest.cs" />
|
||||
<Compile Include="Client\Server\ServerTest.cs" />
|
||||
<Compile Include="FriendsTest.cs" />
|
||||
<Compile Include="GameServerTest.cs" />
|
||||
<Compile Include="Client\Server\StatsTest.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="Client\ServerlistTest.cs" />
|
||||
<Compile Include="Client\StatsTest.cs" />
|
||||
<Compile Include="ServerlistTest.cs" />
|
||||
<Compile Include="StatsTest.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="packages.config" />
|
||||
|
@ -1,63 +1,46 @@
|
||||
using System;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||
/*
|
||||
namespace Facepunch.Steamworks.Test
|
||||
|
||||
namespace Steamworks
|
||||
{
|
||||
[DeploymentItem( "steam_api64.dll" )]
|
||||
[DeploymentItem( "tier0_s64.dll" )]
|
||||
[DeploymentItem( "vstdlib_s64.dll" )]
|
||||
[DeploymentItem( "steamclient64.dll" )]
|
||||
[TestClass]
|
||||
public partial class Server
|
||||
public partial class GameServerTest
|
||||
{
|
||||
[TestMethod]
|
||||
public void Init()
|
||||
{
|
||||
var serverInit = new ServerInit( "rust", "Rust" );
|
||||
serverInit.GamePort = 28015;
|
||||
serverInit.Secure = true;
|
||||
serverInit.QueryPort = 28016;
|
||||
|
||||
using ( var server = new Facepunch.Steamworks.Server( 252490, serverInit ) )
|
||||
{
|
||||
server.ServerName = "My Test Server";
|
||||
server.LogOnAnonymous();
|
||||
|
||||
Assert.IsTrue( server.IsValid );
|
||||
}
|
||||
}
|
||||
GameServer.DedicatedServer = true;
|
||||
GameServer.DedicatedServer = false;
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void PublicIp()
|
||||
public async Task PublicIp()
|
||||
{
|
||||
using ( var server = new Facepunch.Steamworks.Server( 252490, new ServerInit( "rust", "Rust" ) ) )
|
||||
while ( true )
|
||||
{
|
||||
server.LogOnAnonymous();
|
||||
var ip = GameServer.PublicIp;
|
||||
|
||||
Assert.IsTrue( server.IsValid );
|
||||
|
||||
while ( true )
|
||||
if ( ip == null )
|
||||
{
|
||||
var ip = server.PublicIp;
|
||||
|
||||
if ( ip == null )
|
||||
{
|
||||
System.Threading.Thread.Sleep( 100 );
|
||||
server.Update();
|
||||
continue;
|
||||
}
|
||||
|
||||
Assert.IsNotNull( ip );
|
||||
Console.WriteLine( ip.ToString() );
|
||||
break;
|
||||
await Task.Delay( 10 );
|
||||
continue;
|
||||
}
|
||||
|
||||
Assert.IsNotNull( ip );
|
||||
Console.WriteLine( ip.ToString() );
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void AuthCallback()
|
||||
{
|
||||
/*
|
||||
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
||||
{
|
||||
Assert.IsTrue( client.IsValid );
|
||||
@ -144,8 +127,7 @@ namespace Facepunch.Steamworks.Test
|
||||
Assert.IsTrue( !Authed );
|
||||
|
||||
}
|
||||
}
|
||||
}*/
|
||||
}
|
||||
}
|
||||
}
|
||||
*/
|
@ -8,7 +8,15 @@ public static class SteamApi
|
||||
{
|
||||
[DllImport( "Steam_api64", EntryPoint = "SteamAPI_Init", CallingConvention = CallingConvention.Cdecl )]
|
||||
[return: MarshalAs( UnmanagedType.U1 )]
|
||||
public static extern bool Init();
|
||||
public static extern bool SteamAPI_Init();
|
||||
|
||||
[DllImport( "Steam_api64", EntryPoint = "SteamAPI_Shutdown", CallingConvention = CallingConvention.Cdecl )]
|
||||
[return: MarshalAs( UnmanagedType.U1 )]
|
||||
public static extern bool SteamAPI_Shutdown();
|
||||
|
||||
[DllImport( "Steam_api64", EntryPoint = "SteamInternal_GameServer_Init", CallingConvention = CallingConvention.Cdecl )]
|
||||
[return: MarshalAs( UnmanagedType.U1 )]
|
||||
public static extern bool SteamInternal_GameServer_Init( uint unIP, ushort usSteamPort, ushort usGamePort, ushort usQueryPort, int eServerMode, string pchVersionString);
|
||||
|
||||
[DllImport( "Steam_api64", EntryPoint = "SteamAPI_GetHSteamUser", CallingConvention = CallingConvention.Cdecl )]
|
||||
public static extern int GetHSteamUser();
|
||||
@ -17,7 +25,7 @@ public static class SteamApi
|
||||
public static extern int SteamGameServer_GetHSteamUser();
|
||||
|
||||
[DllImport( "Steam_api64", EntryPoint = "SteamAPI_RunCallbacks", CallingConvention = CallingConvention.Cdecl )]
|
||||
public static extern int RunCallbacks();
|
||||
public static extern int SteamAPI_RunCallbacks();
|
||||
|
||||
[DllImport( "Steam_api64", EntryPoint = "SteamAPI_RegisterCallback", CallingConvention = CallingConvention.Cdecl )]
|
||||
public static extern int RegisterCallback( IntPtr pCallback, int callback );
|
||||
|
@ -35,7 +35,7 @@ namespace Steamworks
|
||||
/// </summary>
|
||||
public static event Action<CSteamID, CSteamID, AuthSessionResponse> OnValidateAuthTicketResponse;
|
||||
|
||||
public static bool Init( AppId appid, ServerInit init )
|
||||
public static void Init( AppId appid, ServerInit init )
|
||||
{
|
||||
uint ipaddress = 0; // Any Port
|
||||
|
||||
@ -48,9 +48,9 @@ namespace Steamworks
|
||||
//
|
||||
// Get other interfaces
|
||||
//
|
||||
if ( !Internal.InitGameServer( ipaddress, init.GamePort, init.QueryPort, (uint)( init.Secure ? 3 : 2 ), appid.Value, init.VersionString ) )
|
||||
if ( !global::SteamApi.SteamInternal_GameServer_Init( ipaddress, init.SteamPort, init.GamePort, init.QueryPort, (int)( init.Secure ? 3 : 2 ), init.VersionString ) )
|
||||
{
|
||||
return false;
|
||||
throw new System.Exception( "InitGameServer returned false" );
|
||||
}
|
||||
|
||||
//
|
||||
@ -65,10 +65,25 @@ namespace Steamworks
|
||||
Passworded = false;
|
||||
DedicatedServer = true;
|
||||
|
||||
|
||||
InstallEvents();
|
||||
RunCallbacks();
|
||||
}
|
||||
|
||||
return true;
|
||||
|
||||
internal static async void RunCallbacks()
|
||||
{
|
||||
while ( true )
|
||||
{
|
||||
await Task.Delay( 16 );
|
||||
try
|
||||
{
|
||||
SteamApi.SteamAPI_RunCallbacks();
|
||||
}
|
||||
catch ( System.Exception )
|
||||
{
|
||||
// TODO - error outputs
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -20,7 +20,7 @@ namespace Steamworks
|
||||
System.Environment.SetEnvironmentVariable( "SteamAppId", appid.ToString() );
|
||||
System.Environment.SetEnvironmentVariable( "SteamGameId", appid.ToString() );
|
||||
|
||||
if ( !SteamApi.Init() )
|
||||
if ( !SteamApi.SteamAPI_Init() )
|
||||
{
|
||||
throw new System.Exception( "SteamApi_Init returned false. Steam isn't running, couldn't find Steam, AppId is ureleased, Don't own AppId." );
|
||||
}
|
||||
@ -49,7 +49,7 @@ namespace Steamworks
|
||||
await Task.Delay( 16 );
|
||||
try
|
||||
{
|
||||
SteamApi.RunCallbacks();
|
||||
SteamApi.SteamAPI_RunCallbacks();
|
||||
}
|
||||
catch ( System.Exception )
|
||||
{
|
||||
@ -65,7 +65,7 @@ namespace Steamworks
|
||||
|
||||
public static void Update()
|
||||
{
|
||||
SteamApi.RunCallbacks();
|
||||
SteamApi.SteamAPI_RunCallbacks();
|
||||
}
|
||||
|
||||
internal static void UnregisterCallback( IntPtr intPtr )
|
||||
|
@ -25,7 +25,7 @@ namespace Steamworks.Internal
|
||||
|
||||
if ( server )
|
||||
{
|
||||
Self = SteamInternal.FindOrCreateUserInterface( hUser, InterfaceName );
|
||||
Self = SteamInternal.FindOrCreateGameServerInterface( hUser, InterfaceName );
|
||||
}
|
||||
else
|
||||
{
|
||||
|
Loading…
x
Reference in New Issue
Block a user