2021-02-18 20:45:45 -08:00
|
|
|
using System.IO;
|
2020-06-22 04:43:47 -04:00
|
|
|
using System.Linq;
|
2019-09-19 13:46:01 +02:00
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using NUnit.Framework;
|
2021-02-11 01:13:03 -08:00
|
|
|
using Robust.Server.Maps;
|
|
|
|
|
using Robust.Shared.ContentPack;
|
2019-09-19 13:46:01 +02:00
|
|
|
using Robust.Shared.Map;
|
2021-02-18 20:45:45 -08:00
|
|
|
using Robust.Shared.Timing;
|
2019-09-19 13:46:01 +02:00
|
|
|
using Robust.Shared.Utility;
|
|
|
|
|
|
2020-01-20 22:14:44 +01:00
|
|
|
namespace Content.IntegrationTests.Tests
|
2019-09-19 13:46:01 +02:00
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Tests that the
|
|
|
|
|
/// </summary>
|
|
|
|
|
[TestFixture]
|
2022-02-16 00:23:23 -07:00
|
|
|
public sealed class SaveLoadSaveTest : ContentIntegrationTest
|
2019-09-19 13:46:01 +02:00
|
|
|
{
|
|
|
|
|
[Test]
|
|
|
|
|
public async Task SaveLoadSave()
|
|
|
|
|
{
|
2021-11-06 11:49:59 +01:00
|
|
|
var server = StartServer(new ServerContentIntegrationOption {Pool = false});
|
2019-09-19 13:46:01 +02:00
|
|
|
await server.WaitIdleAsync();
|
|
|
|
|
var mapLoader = server.ResolveDependency<IMapLoader>();
|
|
|
|
|
var mapManager = server.ResolveDependency<IMapManager>();
|
|
|
|
|
server.Post(() =>
|
|
|
|
|
{
|
2020-10-21 17:13:41 +02:00
|
|
|
// TODO: Un-hardcode the grid Id for this test.
|
|
|
|
|
mapLoader.SaveBlueprint(new GridId(1), "save load save 1.yml");
|
2019-11-26 14:16:36 -08:00
|
|
|
var mapId = mapManager.CreateMap();
|
|
|
|
|
var grid = mapLoader.LoadBlueprint(mapId, "save load save 1.yml");
|
2021-02-09 22:04:47 +01:00
|
|
|
mapLoader.SaveBlueprint(grid!.Index, "save load save 2.yml");
|
2019-09-19 13:46:01 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await server.WaitIdleAsync();
|
|
|
|
|
var userData = server.ResolveDependency<IResourceManager>().UserData;
|
|
|
|
|
|
|
|
|
|
string one;
|
|
|
|
|
string two;
|
|
|
|
|
|
2020-08-20 18:47:16 +02:00
|
|
|
var rp1 = new ResourcePath("/save load save 1.yml");
|
2020-06-22 04:43:47 -04:00
|
|
|
using (var stream = userData.Open(rp1, FileMode.Open))
|
2019-09-19 13:46:01 +02:00
|
|
|
using (var reader = new StreamReader(stream))
|
|
|
|
|
{
|
|
|
|
|
one = reader.ReadToEnd();
|
|
|
|
|
}
|
|
|
|
|
|
2020-08-20 18:47:16 +02:00
|
|
|
var rp2 = new ResourcePath("/save load save 2.yml");
|
2020-06-22 04:43:47 -04:00
|
|
|
using (var stream = userData.Open(rp2, FileMode.Open))
|
2019-09-19 13:46:01 +02:00
|
|
|
using (var reader = new StreamReader(stream))
|
|
|
|
|
{
|
|
|
|
|
two = reader.ReadToEnd();
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-22 04:43:47 -04:00
|
|
|
Assert.Multiple(() => {
|
2021-01-15 17:19:52 +01:00
|
|
|
Assert.That(two, Is.EqualTo(one));
|
2020-06-22 04:43:47 -04:00
|
|
|
var failed = TestContext.CurrentContext.Result.Assertions.FirstOrDefault();
|
|
|
|
|
if (failed != null)
|
|
|
|
|
{
|
2021-01-14 20:41:13 +01:00
|
|
|
var oneTmp = Path.GetTempFileName();
|
|
|
|
|
var twoTmp = Path.GetTempFileName();
|
|
|
|
|
|
|
|
|
|
File.WriteAllText(oneTmp, one);
|
|
|
|
|
File.WriteAllText(twoTmp, two);
|
|
|
|
|
|
|
|
|
|
TestContext.AddTestAttachment(oneTmp, "First save file");
|
|
|
|
|
TestContext.AddTestAttachment(twoTmp, "Second save file");
|
2020-06-22 04:43:47 -04:00
|
|
|
TestContext.Error.WriteLine("Complete output:");
|
2021-01-14 20:41:13 +01:00
|
|
|
TestContext.Error.WriteLine(oneTmp);
|
|
|
|
|
TestContext.Error.WriteLine(twoTmp);
|
2020-06-22 04:43:47 -04:00
|
|
|
}
|
|
|
|
|
});
|
2019-09-19 13:46:01 +02:00
|
|
|
}
|
2019-10-13 16:26:39 +02:00
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Loads the default map, runs it for 5 ticks, then assert that it did not change.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Test]
|
2021-02-04 12:44:27 +00:00
|
|
|
public async Task LoadSaveTicksSaveSaltern()
|
2019-10-13 16:26:39 +02:00
|
|
|
{
|
2020-01-20 22:17:51 +01:00
|
|
|
var server = StartServerDummyTicker();
|
2019-10-13 16:26:39 +02:00
|
|
|
await server.WaitIdleAsync();
|
|
|
|
|
var mapLoader = server.ResolveDependency<IMapLoader>();
|
|
|
|
|
var mapManager = server.ResolveDependency<IMapManager>();
|
|
|
|
|
|
|
|
|
|
IMapGrid grid = default;
|
|
|
|
|
|
2021-11-06 11:49:59 +01:00
|
|
|
// Load saltern.yml as uninitialized map, and save it to ensure it's up to date.
|
2019-10-13 16:26:39 +02:00
|
|
|
server.Post(() =>
|
|
|
|
|
{
|
2019-11-26 14:16:36 -08:00
|
|
|
var mapId = mapManager.CreateMap();
|
2022-02-21 14:41:50 +11:00
|
|
|
mapManager.AddUninitializedMap(mapId);
|
|
|
|
|
mapManager.SetMapPaused(mapId, true);
|
2021-02-04 12:44:27 +00:00
|
|
|
grid = mapLoader.LoadBlueprint(mapId, "Maps/saltern.yml");
|
2019-10-13 16:26:39 +02:00
|
|
|
mapLoader.SaveBlueprint(grid.Index, "load save ticks save 1.yml");
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Run 5 ticks.
|
|
|
|
|
server.RunTicks(5);
|
|
|
|
|
|
|
|
|
|
server.Post(() =>
|
|
|
|
|
{
|
2020-08-20 18:47:16 +02:00
|
|
|
mapLoader.SaveBlueprint(grid.Index, "/load save ticks save 2.yml");
|
2019-10-13 16:26:39 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await server.WaitIdleAsync();
|
|
|
|
|
var userData = server.ResolveDependency<IResourceManager>().UserData;
|
|
|
|
|
|
|
|
|
|
string one;
|
|
|
|
|
string two;
|
|
|
|
|
|
2020-08-20 18:47:16 +02:00
|
|
|
using (var stream = userData.Open(new ResourcePath("/load save ticks save 1.yml"), FileMode.Open))
|
2019-10-13 16:26:39 +02:00
|
|
|
using (var reader = new StreamReader(stream))
|
|
|
|
|
{
|
|
|
|
|
one = reader.ReadToEnd();
|
|
|
|
|
}
|
|
|
|
|
|
2020-08-20 18:47:16 +02:00
|
|
|
using (var stream = userData.Open(new ResourcePath("/load save ticks save 2.yml"), FileMode.Open))
|
2019-10-13 16:26:39 +02:00
|
|
|
using (var reader = new StreamReader(stream))
|
|
|
|
|
{
|
|
|
|
|
two = reader.ReadToEnd();
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-04 18:11:52 +02:00
|
|
|
Assert.Multiple(() => {
|
|
|
|
|
Assert.That(two, Is.EqualTo(one));
|
|
|
|
|
var failed = TestContext.CurrentContext.Result.Assertions.FirstOrDefault();
|
|
|
|
|
if (failed != null)
|
|
|
|
|
{
|
|
|
|
|
var oneTmp = Path.GetTempFileName();
|
|
|
|
|
var twoTmp = Path.GetTempFileName();
|
|
|
|
|
|
|
|
|
|
File.WriteAllText(oneTmp, one);
|
|
|
|
|
File.WriteAllText(twoTmp, two);
|
|
|
|
|
|
|
|
|
|
TestContext.AddTestAttachment(oneTmp, "First save file");
|
|
|
|
|
TestContext.AddTestAttachment(twoTmp, "Second save file");
|
|
|
|
|
TestContext.Error.WriteLine("Complete output:");
|
|
|
|
|
TestContext.Error.WriteLine(oneTmp);
|
|
|
|
|
TestContext.Error.WriteLine(twoTmp);
|
|
|
|
|
}
|
|
|
|
|
});
|
2019-10-13 16:26:39 +02:00
|
|
|
}
|
2019-09-19 13:46:01 +02:00
|
|
|
}
|
|
|
|
|
}
|