編輯

共用方式為


Why international validation is important

Ensuring world-readiness has a wider scope and requires more planning than just testing your app after the UI strings have been translated.

Historically, some product teams have initially focused on producing a single-language product for a single market, and not on meeting the needs of multiple international markets. When working with an existing codebase, a solid international Quality Assurance (QA) process is critical to ensuring that the functionality and appearance of the product is appropriate for the new target markets. This QA process should cover all aspects of internationalization.

The Quality Assurance (QA) process is ideally a partnership between the development team, project managers, and other functions. The goal is to establish clear criteria for international release and verify that these are met throughout the product lifecycle, including design, development, distribution, and support. Your whole QA process should be globalized for the best result, with all the international requirements baked in before any testing is done. This article describes what that entails.

Timeline of the international validation process

International validation usually proceeds like this:

  1. Define your target markets and languages.
  2. Define what requirements need to be met to reach those markets in the chosen languages.
  3. Validate that your product meets general internationalization requirements.
  4. Validate your product's localization readiness.
  5. Validate the localized product.

Common globalization issues

Software design and development can easily break world-readiness when:

  • Legacy single-language methods, thinking, and practices are used.
  • International conventions aren't considered.
  • Text layout and other text properties aren't designed for.

The most serious globalization problem is functionality loss. This problem can surface immediately, such as when a language or locale is changed. It might also surface later, such as when accessing non-Latin character input.

Some functionality problems manifest themselves in the form of display problems. The following are some common ones that you might see:

  • Question marks (?) or random characters (¼, «, †, ‰, ‡, ¶, and so on) appearing instead of text can indicate an issue converting text from one code page to another.
  • The appearance of default glyphs (usually boxes) indicates that the selected font can't display some of the characters. This can be an issue with font selection or another encoding issue.
  • Text appears truncated or overlapping.

It might be hard to find certain problems in display or print results without having adequate layout, script, or shaping knowledge. Testing for these sorts of problems is language-specific and often can't be executed without language expertise.

Another area of potential problems is code failing to follow locale conventions as defined by the regional format settings. Make sure that locale-sensitive data in your app (numbers, dates, time, currency, and calendars) respects the user’s Region settings.

However, Language and Region settings don’t cover all locale-specific functionality. You can’t see the current sort order there, for example. Thus, it's important to have a test plan covering all aspects of functionality related to locale before you start your test. You can use the .NET Framework documentation as a starting point for this plan. Use the documentation to find exactly what locale information you need to retrieve dynamically, and then apply those requirements to your project.

When planning and running tests, remember that globalization is wider in scope than just supporting one particular language. The test you use to verify that code has been globalized might not replicate a realistic user scenario. The settings of a particular globalized test might look unnatural or extreme. However, by covering a wide range of conditions, the test produces more comprehensive results. Similarly, your test should include potential markets you might not have considered or even heard of, and the multiple ways in which your product might be used.

Test tools

Test tools, especially automated tools, play an essential role in the testing process. While automated testing can't completely replace manual testing, many test areas gain tremendous benefits from automation. For instance, using automated test tools is an effective way to verify the functionality of a localized product. Automated tests can validate the degree of a product's globalization.

Running automated tests on the original and localized applications side by side can verify that localization doesn't break any functionality. With automation, you don't need to understand the language of the localized UI since the tools can test the functionality regardless of the language. For instance, "Select the default button" is a test of functionality that can work for any language.

Ensuring that a product is globalized requires the ranges of test input to be extended, and environment settings to be more diverse. Automation makes it easier to deal with the additional test cases and allows you to efficiently track the results. Restoring the locale settings or test input that brought about an error in a program also becomes easier.

Globalized test tools

Automation of test runs involves more than just running your usual test tools on your new product under a globalized environment. Test tools that check the functionality of your app UI can be broken when the tested application is translated. Even when not affected by translation, test results might be incorrect if the tool verifies locale-formatted data and assumes that the data format is fixed. For example, in globalized applications, the date format varies according to locale and region. The inability to use international test data can make a test tool unusable.

To avoid these and similar problems, developers of test tools must follow the same rules as the developers of globalized software do. Test tools must be globalized, adjust themselves dynamically to locale settings, and process international text data. If they must access localizable objects by name, the test tools must also be localized.

Experience shows that some tools are easy to globalize, while others aren't. More advanced programming models usually provide better ways to make the code universal regarding locale and language settings.

What comes next

Once you verify that a product's functionality has been globalized by globalizing the existing testing, you need to determine whether the application is going to be localized. If so, the next step is internationalization testing, discussed in When to perform internationalization testing and How to perform internationalization testing.

After internationalization testing is done, its findings implemented, and at least one or two languages have been localized, it’s time to carry out localization testing. For more information, see How to perform localization testing.