add integration test for serializer
This commit is contained in:
committed by
Pieter-Jan Briers
parent
a8f84c4b8c
commit
0e286ad808
@@ -12,6 +12,7 @@
|
|||||||
<Import Project="..\RobustToolbox\MSBuild\Robust.DefineConstants.targets" />
|
<Import Project="..\RobustToolbox\MSBuild\Robust.DefineConstants.targets" />
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="NUnit" Version="3.12.0" />
|
<PackageReference Include="NUnit" Version="3.12.0" />
|
||||||
|
<PackageReference Include="NUnit.DeepObjectCompare" Version="2.0.0" />
|
||||||
<PackageReference Include="NUnit3TestAdapter" Version="3.16.1" />
|
<PackageReference Include="NUnit3TestAdapter" Version="3.16.1" />
|
||||||
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="16.4.0" />
|
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="16.4.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|||||||
83
Content.IntegrationTests/Tests/SerializerTest.cs
Normal file
83
Content.IntegrationTests/Tests/SerializerTest.cs
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using Robust.Server.Interfaces.GameObjects;
|
||||||
|
using Robust.Server.Interfaces.Player;
|
||||||
|
using Robust.Shared.Enums;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.Interfaces.GameObjects;
|
||||||
|
using Robust.Shared.Interfaces.Network;
|
||||||
|
using Robust.Shared.Interfaces.Serialization;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Serialization;
|
||||||
|
using Robust.Shared.Timing;
|
||||||
|
using Is = NUnit.DeepObjectCompare.Is;
|
||||||
|
|
||||||
|
namespace Content.IntegrationTests.Tests
|
||||||
|
{
|
||||||
|
|
||||||
|
public class SerializerTest : ContentIntegrationTest
|
||||||
|
{
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public async Task EntityStatesTest()
|
||||||
|
{
|
||||||
|
RobustSerializer._traceWriter = Console.Out;
|
||||||
|
var client = StartClient();
|
||||||
|
var server = StartServer();
|
||||||
|
|
||||||
|
await Task.WhenAll(client.WaitIdleAsync(), server.WaitIdleAsync());
|
||||||
|
|
||||||
|
// Connect.
|
||||||
|
|
||||||
|
client.SetConnectTarget(server);
|
||||||
|
|
||||||
|
client.Post(() => IoCManager.Resolve<IClientNetManager>().ClientConnect(null, 0, null));
|
||||||
|
|
||||||
|
// Run some ticks for the handshake to complete and such.
|
||||||
|
|
||||||
|
server.RunTicks(1);
|
||||||
|
await server.WaitIdleAsync();
|
||||||
|
client.RunTicks(1);
|
||||||
|
await client.WaitIdleAsync();
|
||||||
|
|
||||||
|
await Task.WhenAll(client.WaitIdleAsync(), server.WaitIdleAsync());
|
||||||
|
|
||||||
|
// Basic checks to ensure that they're connected and data got replicated.
|
||||||
|
|
||||||
|
var mtx = new ManualResetEventSlim();
|
||||||
|
List<EntityState> es = null;
|
||||||
|
|
||||||
|
server.Post(() =>
|
||||||
|
{
|
||||||
|
var sem = IoCManager.Resolve<IServerEntityManager>();
|
||||||
|
es = sem.GetEntityStates(GameTick.Zero);
|
||||||
|
mtx.Set();
|
||||||
|
});
|
||||||
|
mtx.Wait();
|
||||||
|
|
||||||
|
Assert.NotNull(es);
|
||||||
|
|
||||||
|
var serializer = new RobustSerializer();
|
||||||
|
|
||||||
|
List<EntityState> roundTrip;
|
||||||
|
|
||||||
|
using (var ms = new MemoryStream())
|
||||||
|
{
|
||||||
|
serializer.Serialize(ms, es);
|
||||||
|
ms.Position = 0;
|
||||||
|
roundTrip = (List<EntityState>)serializer.Deserialize(ms);
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.That(roundTrip, Is.DeepEqualTo(es));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -115,10 +115,10 @@ Global
|
|||||||
{4809F412-3132-419E-BF9D-CCF7593C3533}.Debug|x64.Build.0 = Debug|x64
|
{4809F412-3132-419E-BF9D-CCF7593C3533}.Debug|x64.Build.0 = Debug|x64
|
||||||
{4809F412-3132-419E-BF9D-CCF7593C3533}.Release|x64.ActiveCfg = Release|x64
|
{4809F412-3132-419E-BF9D-CCF7593C3533}.Release|x64.ActiveCfg = Release|x64
|
||||||
{4809F412-3132-419E-BF9D-CCF7593C3533}.Release|x64.Build.0 = Release|x64
|
{4809F412-3132-419E-BF9D-CCF7593C3533}.Release|x64.Build.0 = Release|x64
|
||||||
{45C9B43F-305D-4651-9863-F6384CBC847F}.Debug|x64.ActiveCfg = Debug|Any CPU
|
{45C9B43F-305D-4651-9863-F6384CBC847F}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{45C9B43F-305D-4651-9863-F6384CBC847F}.Debug|x64.Build.0 = Debug|Any CPU
|
{45C9B43F-305D-4651-9863-F6384CBC847F}.Debug|x64.Build.0 = Debug|x64
|
||||||
{45C9B43F-305D-4651-9863-F6384CBC847F}.Release|x64.ActiveCfg = Release|Any CPU
|
{45C9B43F-305D-4651-9863-F6384CBC847F}.Release|x64.ActiveCfg = Release|x64
|
||||||
{45C9B43F-305D-4651-9863-F6384CBC847F}.Release|x64.Build.0 = Release|Any CPU
|
{45C9B43F-305D-4651-9863-F6384CBC847F}.Release|x64.Build.0 = Release|x64
|
||||||
{A3A97D48-6128-4330-B962-B4A96F018CE8}.Debug|x64.ActiveCfg = Debug|Any CPU
|
{A3A97D48-6128-4330-B962-B4A96F018CE8}.Debug|x64.ActiveCfg = Debug|Any CPU
|
||||||
{A3A97D48-6128-4330-B962-B4A96F018CE8}.Debug|x64.Build.0 = Debug|Any CPU
|
{A3A97D48-6128-4330-B962-B4A96F018CE8}.Debug|x64.Build.0 = Debug|Any CPU
|
||||||
{A3A97D48-6128-4330-B962-B4A96F018CE8}.Release|x64.ActiveCfg = Release|Any CPU
|
{A3A97D48-6128-4330-B962-B4A96F018CE8}.Release|x64.ActiveCfg = Release|Any CPU
|
||||||
|
|||||||
Reference in New Issue
Block a user