Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add "nl" resx files #97

Merged
merged 2 commits into from
Oct 17, 2022

Conversation

jeroenheijmans
Copy link
Contributor

This adds Dutch ("NL") translations for all existing .resx files in all various projects.

Fixes #94

I was debating how (and if) to include updated test coverage for these changes. All current tests keep passing on my machine. But adding test coverage in a maintainable way presents a few choices about the test setup.

First up, I have confirmed to some degree with tests that this is working, by modifying an existing test into this one:

[Fact]
public void When_creating_instance_it_should_have_expected_message___AdhocTestOfLocalization()
{
    // Adhoc fact to verify if localization of error messages is working.
    CultureInfo.DefaultThreadCurrentUICulture = new CultureInfo("nl-NL");
    var country = new IbanCountry("NL") { DisplayName = "The display name" };
    var sut = new CountryNotAcceptedResult(country);
    sut.ErrorMessage.Should().Be("Bankrekeningnummers van het land The display name worden niet geaccepteerd.");
}

It hard-coded verifies that the error message picks up the Dutch translation.

Unfortunately there does not seem to be a super-widespread way to make tests run for multiple cultures using xUnit. This requires a custom attribute (with all associated maintenance) it seems.

At first thought, I see these options (that can be mixed and matched) as far as testing goes:

  1. Do nothing. Just rely on an occasional check that this is working.
  2. Write a smoke test with some reflection to ensure all resx items have been translated into all supported languages. (So test the presence of translations.)
  3. Create an xUnit attribute (or find a contrib package that does so) to re-run specific tests for different cultures. Apply this attribute to existing tests that check localization.
  4. Write one (bit more hard coded) test per csproj/language to verify that the resx for that language/project is being picked up.

Surely there are more options too?

I stuck with "1" for the moment. Let me know if I can and should support some more in this regard?

This adds Dutch ("NL") translations for all existing .resx files in
all various projects.

Fixes skwasjer#94
@skwasjer
Copy link
Owner

skwasjer commented Oct 17, 2022

Thanks, lgtm.

I would not worry too much about covering localization throughout the solution atm. One trick is to set the locale before running dotnet test such that the test runner inherits the culture from the OS. That way, although all tests must be run for each locale, it is an agnostic approach that does not require polluting the tests themselves. Just another GitHub action job matrix.

I do not prefer a methodology that could prevent future CI pipelines to continue in the case of a missing translation. I might not have translators on-hand to help translating new text that is added, nor would I want it to block a new feature being released because of it. In such cases, the fallback to English should be allowed.

So for now, I am gonna agree with you and stay with no. 1) 👍

@skwasjer skwasjer merged commit 2089117 into skwasjer:main Oct 17, 2022
@jeroenheijmans jeroenheijmans deleted the 94-add-localized-resx-for-nl branch October 17, 2022 21:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

How to have translated validation error messages?
2 participants