Files
wwdpublic/Content.IntegrationTests/Tests/Language/LanguageLocalizationTest.cs
Sapphire 4e0cd4d17c Add Language Localization Integration Test (#1419)
# Description

I'll add the missing localization strings in a separate PR.

---

<details><summary><h1>Media</h1></summary>
<p>

![image](https://github.com/user-attachments/assets/758618c1-ded3-4476-a6cd-3262cd169a24)

</p>
</details>

---

Co-authored-by: sleepyyapril <123355664+sleepyyapril@users.noreply.github.com>
(cherry picked from commit 25af8012afe23dd5e4ffa213281e269abbdf7b60)
2025-01-14 01:12:17 +03:00

40 lines
1.4 KiB
C#

using Robust.Shared.Prototypes;
using Robust.Shared.Localization;
using Content.Shared.Language;
using System.Linq;
using System.Collections.Generic;
namespace Content.IntegrationTests.Tests.Traits;
/// <summary>
/// Checks if every language has a valid name, chatname, and description localization string.
/// </summary>
[TestFixture]
[TestOf(typeof(LanguagePrototype))]
public sealed class LanguageLocalizationTest
{
[Test]
public async Task TestLanguageLocalization()
{
await using var pair = await PoolManager.GetServerClient();
var server = pair.Server;
var locale = server.ResolveDependency<ILocalizationManager>();
var proto = server.ResolveDependency<IPrototypeManager>();
await server.WaitAssertion(() =>
{
var missingStrings = new List<string>();
foreach (var langProto in proto.EnumeratePrototypes<LanguagePrototype>().OrderBy(a => a.ID))
foreach (var locString in new List<string> { $"language-{langProto.ID}-name", $"chat-language-{langProto.ID}-name", $"language-{langProto.ID}-description" })
if (!locale.HasString(locString))
missingStrings.Add($"\"{langProto.ID}\", \"{locString}\"");
Assert.That(!missingStrings.Any(), Is.True, $"The following languages are missing localization strings:\n {string.Join("\n ", missingStrings)}");
});
await pair.CleanReturnAsync();
}
}