2023-07-05 21:54:25 -07:00
|
|
|
|
using System.Collections.Generic;
|
2021-11-22 23:15:22 +01:00
|
|
|
|
using System.Linq;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
using Content.Server.Administration.Logs;
|
|
|
|
|
|
using Content.Server.Database;
|
2021-11-24 18:52:16 +01:00
|
|
|
|
using Content.Server.GameTicking;
|
2021-12-25 02:07:12 +01:00
|
|
|
|
using Content.Shared.Administration.Logs;
|
2021-11-28 14:56:53 +01:00
|
|
|
|
using Content.Shared.Database;
|
2021-11-22 23:15:22 +01:00
|
|
|
|
using Robust.Server.Player;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
using Robust.Shared.GameObjects;
|
|
|
|
|
|
|
|
|
|
|
|
namespace Content.IntegrationTests.Tests.Administration.Logs;
|
|
|
|
|
|
|
|
|
|
|
|
[TestFixture]
|
|
|
|
|
|
[TestOf(typeof(AdminLogSystem))]
|
2022-06-19 20:22:28 -07:00
|
|
|
|
public sealed class AddTests
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2023-08-06 14:30:28 +12:00
|
|
|
|
public static PoolSettings LogTestSettings = new()
|
|
|
|
|
|
{
|
|
|
|
|
|
AdminLogsEnabled = true,
|
|
|
|
|
|
DummyTicker = false,
|
|
|
|
|
|
Connected = true
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2021-11-22 19:08:27 +01:00
|
|
|
|
[Test]
|
|
|
|
|
|
public async Task AddAndGetSingleLog()
|
|
|
|
|
|
{
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(LogTestSettings);
|
|
|
|
|
|
var server = pair.Server;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
var sEntities = server.ResolveDependency<IEntityManager>();
|
|
|
|
|
|
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
|
|
|
|
|
var guid = Guid.NewGuid();
|
|
|
|
|
|
|
2024-04-20 17:01:15 -04:00
|
|
|
|
await pair.CreateTestMap();
|
|
|
|
|
|
var coordinates = pair.TestMap.GridCoords;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
var entity = sEntities.SpawnEntity(null, coordinates);
|
|
|
|
|
|
|
|
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"{entity:Entity} test log: {guid}");
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
|
|
|
|
|
var logs = sAdminLogSystem.CurrentRoundJson(new LogFilter
|
|
|
|
|
|
{
|
|
|
|
|
|
Search = guid.ToString()
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
await foreach (var json in logs)
|
|
|
|
|
|
{
|
|
|
|
|
|
var root = json.RootElement;
|
|
|
|
|
|
|
|
|
|
|
|
// camelCased automatically
|
|
|
|
|
|
Assert.That(root.TryGetProperty("entity", out _), Is.True);
|
|
|
|
|
|
|
|
|
|
|
|
json.Dispose();
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
});
|
2022-06-19 20:22:28 -07:00
|
|
|
|
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
|
public async Task AddAndGetUnformattedLog()
|
|
|
|
|
|
{
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(LogTestSettings);
|
|
|
|
|
|
var server = pair.Server;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
|
|
|
|
|
var sDatabase = server.ResolveDependency<IServerDbManager>();
|
|
|
|
|
|
var sEntities = server.ResolveDependency<IEntityManager>();
|
|
|
|
|
|
var sSystems = server.ResolveDependency<IEntitySystemManager>();
|
|
|
|
|
|
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-12-25 02:07:12 +01:00
|
|
|
|
var sGamerTicker = sSystems.GetEntitySystem<GameTicker>();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
|
|
|
|
|
var guid = Guid.NewGuid();
|
|
|
|
|
|
|
2023-08-25 04:13:11 +02:00
|
|
|
|
var testMap = await pair.CreateTestMap();
|
2022-06-21 07:44:19 -07:00
|
|
|
|
var coordinates = testMap.GridCoords;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
var entity = sEntities.SpawnEntity(null, coordinates);
|
|
|
|
|
|
|
|
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"{entity} test log: {guid}");
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
SharedAdminLog log = default;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
var logs = await sAdminLogSystem.CurrentRoundLogs(new LogFilter
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
|
|
|
|
|
Search = guid.ToString()
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
if (logs.Count == 0)
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
return false;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
log = logs.First();
|
|
|
|
|
|
return true;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
});
|
|
|
|
|
|
|
2021-11-24 18:52:16 +01:00
|
|
|
|
var filter = new LogFilter
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
Round = sGamerTicker.RoundId,
|
2021-11-24 18:52:16 +01:00
|
|
|
|
Search = log.Message,
|
2023-07-05 21:54:25 -07:00
|
|
|
|
Types = new HashSet<LogType> { log.Type },
|
2021-11-24 18:52:16 +01:00
|
|
|
|
};
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
2021-11-24 18:52:16 +01:00
|
|
|
|
await foreach (var json in sDatabase.GetAdminLogsJson(filter))
|
|
|
|
|
|
{
|
|
|
|
|
|
var root = json.RootElement;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
2023-07-05 21:54:25 -07:00
|
|
|
|
Assert.Multiple(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
Assert.That(root.TryGetProperty("entity", out _), Is.True);
|
|
|
|
|
|
Assert.That(root.TryGetProperty("guid", out _), Is.True);
|
|
|
|
|
|
});
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
2021-11-24 18:52:16 +01:00
|
|
|
|
json.Dispose();
|
|
|
|
|
|
}
|
2022-06-19 20:22:28 -07:00
|
|
|
|
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
2021-12-25 02:07:12 +01:00
|
|
|
|
[TestCase(500)]
|
|
|
|
|
|
public async Task BulkAddLogs(int amount)
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(LogTestSettings);
|
|
|
|
|
|
var server = pair.Server;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
|
|
|
|
|
var sEntities = server.ResolveDependency<IEntityManager>();
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
2023-08-25 04:13:11 +02:00
|
|
|
|
var testMap = await pair.CreateTestMap();
|
2022-06-21 07:44:19 -07:00
|
|
|
|
var coordinates = testMap.GridCoords;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
2021-12-05 18:09:01 +01:00
|
|
|
|
var entity = sEntities.SpawnEntity(null, coordinates);
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
for (var i = 0; i < amount; i++)
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"{entity:Entity} test log.");
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
var messages = await sAdminLogSystem.CurrentRoundLogs();
|
|
|
|
|
|
return messages.Count >= amount;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
});
|
2022-06-19 20:22:28 -07:00
|
|
|
|
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
2021-11-22 23:15:22 +01:00
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
|
public async Task AddPlayerSessionLog()
|
|
|
|
|
|
{
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(LogTestSettings);
|
|
|
|
|
|
var server = pair.Server;
|
2021-11-22 23:15:22 +01:00
|
|
|
|
|
|
|
|
|
|
var sPlayers = server.ResolveDependency<IPlayerManager>();
|
|
|
|
|
|
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-11-22 23:15:22 +01:00
|
|
|
|
Guid playerGuid = default;
|
|
|
|
|
|
|
|
|
|
|
|
await server.WaitPost(() =>
|
2021-11-24 18:52:16 +01:00
|
|
|
|
{
|
2023-10-28 09:59:53 +11:00
|
|
|
|
var player = sPlayers.Sessions.First();
|
2021-11-22 23:15:22 +01:00
|
|
|
|
playerGuid = player.UserId;
|
|
|
|
|
|
|
|
|
|
|
|
Assert.DoesNotThrow(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"{player:Player} test log.");
|
|
|
|
|
|
});
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-11-22 23:15:22 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
var logs = await sAdminLogSystem.CurrentRoundLogs();
|
|
|
|
|
|
if (logs.Count == 0)
|
2021-11-22 23:15:22 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
return false;
|
2021-11-22 23:15:22 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
Assert.That(logs.First().Players, Does.Contain(playerGuid));
|
|
|
|
|
|
return true;
|
2021-11-22 23:15:22 +01:00
|
|
|
|
});
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-11-22 23:15:22 +01:00
|
|
|
|
}
|
2021-11-24 18:52:16 +01:00
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
|
public async Task PreRoundAddAndGetSingle()
|
|
|
|
|
|
{
|
2023-08-06 14:30:28 +12:00
|
|
|
|
var setting = new PoolSettings
|
|
|
|
|
|
{
|
|
|
|
|
|
Dirty = true,
|
|
|
|
|
|
InLobby = true,
|
|
|
|
|
|
AdminLogsEnabled = true
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(setting);
|
|
|
|
|
|
var server = pair.Server;
|
2022-06-19 20:22:28 -07:00
|
|
|
|
|
2021-11-24 18:52:16 +01:00
|
|
|
|
var sDatabase = server.ResolveDependency<IServerDbManager>();
|
|
|
|
|
|
var sSystems = server.ResolveDependency<IEntitySystemManager>();
|
|
|
|
|
|
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-11-24 18:52:16 +01:00
|
|
|
|
var sGamerTicker = sSystems.GetEntitySystem<GameTicker>();
|
|
|
|
|
|
|
|
|
|
|
|
var guid = Guid.NewGuid();
|
|
|
|
|
|
|
|
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
2022-03-04 23:25:41 +01:00
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"test log: {guid}");
|
2021-11-24 18:52:16 +01:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
sGamerTicker.StartRound(true);
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
SharedAdminLog log = default;
|
2021-11-24 18:52:16 +01:00
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-11-24 18:52:16 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
var logs = await sAdminLogSystem.CurrentRoundLogs(new LogFilter
|
2021-11-24 18:52:16 +01:00
|
|
|
|
{
|
|
|
|
|
|
Search = guid.ToString()
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
if (logs.Count == 0)
|
2021-11-24 18:52:16 +01:00
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
return false;
|
2021-11-24 18:52:16 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-25 02:07:12 +01:00
|
|
|
|
log = logs.First();
|
|
|
|
|
|
return true;
|
2021-11-24 18:52:16 +01:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
var filter = new LogFilter
|
|
|
|
|
|
{
|
2021-12-25 02:07:12 +01:00
|
|
|
|
Round = sGamerTicker.RoundId,
|
2021-11-24 18:52:16 +01:00
|
|
|
|
Search = log.Message,
|
2023-07-05 21:54:25 -07:00
|
|
|
|
Types = new HashSet<LogType> { log.Type },
|
2021-11-24 18:52:16 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
await foreach (var json in sDatabase.GetAdminLogsJson(filter))
|
|
|
|
|
|
{
|
|
|
|
|
|
var root = json.RootElement;
|
2022-05-28 23:41:17 -07:00
|
|
|
|
|
2021-11-24 18:52:16 +01:00
|
|
|
|
Assert.That(root.TryGetProperty("guid", out _), Is.True);
|
|
|
|
|
|
|
|
|
|
|
|
json.Dispose();
|
|
|
|
|
|
}
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-11-24 18:52:16 +01:00
|
|
|
|
}
|
2021-12-26 00:38:04 +01:00
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
|
public async Task DuplicatePlayerDoesNotThrowTest()
|
|
|
|
|
|
{
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(LogTestSettings);
|
|
|
|
|
|
var server = pair.Server;
|
2021-12-26 00:38:04 +01:00
|
|
|
|
|
|
|
|
|
|
var sPlayers = server.ResolveDependency<IPlayerManager>();
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-12-26 00:38:04 +01:00
|
|
|
|
|
|
|
|
|
|
var guid = Guid.NewGuid();
|
|
|
|
|
|
|
|
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
2023-10-28 09:59:53 +11:00
|
|
|
|
var player = sPlayers.Sessions.Single();
|
2021-12-26 00:38:04 +01:00
|
|
|
|
|
|
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"{player} {player} test log: {guid}");
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-12-26 00:38:04 +01:00
|
|
|
|
{
|
|
|
|
|
|
var logs = await sAdminLogSystem.CurrentRoundLogs(new LogFilter
|
|
|
|
|
|
{
|
|
|
|
|
|
Search = guid.ToString()
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
if (logs.Count == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-12-26 00:38:04 +01:00
|
|
|
|
Assert.Pass();
|
|
|
|
|
|
}
|
2021-12-26 00:50:10 +01:00
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
|
public async Task DuplicatePlayerIdDoesNotThrowTest()
|
|
|
|
|
|
{
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await using var pair = await PoolManager.GetServerClient(LogTestSettings);
|
|
|
|
|
|
var server = pair.Server;
|
2021-12-26 00:50:10 +01:00
|
|
|
|
|
|
|
|
|
|
var sPlayers = server.ResolveDependency<IPlayerManager>();
|
|
|
|
|
|
|
2022-05-28 23:41:17 -07:00
|
|
|
|
var sAdminLogSystem = server.ResolveDependency<IAdminLogManager>();
|
2021-12-26 00:50:10 +01:00
|
|
|
|
|
|
|
|
|
|
var guid = Guid.NewGuid();
|
|
|
|
|
|
|
|
|
|
|
|
await server.WaitPost(() =>
|
|
|
|
|
|
{
|
2023-10-28 09:59:53 +11:00
|
|
|
|
var player = sPlayers.Sessions.Single();
|
2021-12-26 00:50:10 +01:00
|
|
|
|
|
|
|
|
|
|
sAdminLogSystem.Add(LogType.Unknown, $"{player:first} {player:second} test log: {guid}");
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2022-06-19 20:22:28 -07:00
|
|
|
|
await PoolManager.WaitUntil(server, async () =>
|
2021-12-26 00:50:10 +01:00
|
|
|
|
{
|
|
|
|
|
|
var logs = await sAdminLogSystem.CurrentRoundLogs(new LogFilter
|
|
|
|
|
|
{
|
|
|
|
|
|
Search = guid.ToString()
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
if (logs.Count == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2023-08-25 02:56:51 +02:00
|
|
|
|
await pair.CleanReturnAsync();
|
2021-12-26 00:50:10 +01:00
|
|
|
|
Assert.Pass();
|
|
|
|
|
|
}
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|