Skip to main content
Version: 3.x.x

Translation QA Checks

When managing translations across many languages, it's easy for localization errors to slip through. A translator might accidentally remove a placeholder, break placeholder syntax, add extra spaces, or miss punctuation. These translation quality issues are hard to spot manually, especially at scale, and can lead to broken UI, missing data, or confusing user experiences.

QA Checks solve this by automatically validating your translations and flagging potential issues such as missing placeholders, broken placeholder syntax, inconsistent punctuation, spelling and grammar errors, and more. Issues are detected in real time as you type and also run in the background when translations are saved or modified in bulk.

Feature availability

QA Checks are available in advanced plans. Upgrade your plan to use this feature.

If you use the self-hosted version, you must set up the license to use this feature.

Enabling QA Checks

If you would like to start using QA checks, you have to enable them first. To enable QA checks

  1. Go to Project settings
  2. Find the QA Checks section
  3. Toggle QA Checks on

Once enabled, Tolgee will automatically run checks on all translations in the project. You'll see a progress indicator while the initial check completes.

Available Check Types

Tolgee provides check types organized into two categories: general checks that catch common translation issues, and syntax checks that validate the structure of the translation itself.

General Checks

These checks catch common translation issues such as formatting inconsistencies, missing content, and spelling or grammar errors

CheckDescription
Empty translationDetects blank or whitespace-only translations (off by default)
Spaces mismatchLeading/trailing space differences, doubled spaces, non-breaking spaces
Unmatched new linesMissing or extra line breaks compared to the base translation
Character case mismatchCapitalization differences (e.g., first letter case)
Missing numbersNumeric values present in the base but missing in the translation
Punctuation mismatchMissing, extra, or replaced punctuation marks
Brackets mismatchMissing or extra brackets compared to the base
Brackets unbalancedUnclosed or unopened brackets within the translation
Special character mismatchMissing or extra special characters (off by default)
Different URLsURLs that are missing, extra, or different from the base
Key length limitTranslation exceeds the key's configured character limit
SpellingSpelling errors (off by default)
GrammarGrammar errors (off by default)
Repeated wordsConsecutive repeated words (e.g., "the the")
Unresolved commentsTranslation has unresolved comments that should be addressed

Syntax Checks

These checks validate the structure and syntax of the translation itself

CheckDescription
Inconsistent placeholdersVariable placeholders (e.g., {userName}) missing or extra compared to the base
Inconsistent HTMLHTML tags missing or extra compared to the base
HTML syntaxUnclosed or unopened HTML tags
ICU syntaxInvalid message format (select, plural, choice expressions)

Viewing QA Issues

In the Translation Editor

To help translators catch issues as they work, QA checks are shown directly in the translation editor. When you open a translation for editing, the QA checks panel appears below the text field. Each issue shows

  • The check type (e.g., "Spaces mismatch")
  • A description of what was detected
  • A suggested replacement when available, with highlighted differences

Issues are updated in real time as you type, so you get immediate feedback on your changes.

Inline Highlights

Problematic text spans are highlighted directly in the translation editor. Hovering over a highlight shows the issue details and a suggested fix.

QA Badge

A QA badge appears next to translations in the translations list view when there are open issues or checks are still running

  • Badge with count - number of open issues
  • Spinner - checks are still running (e.g., after an import or settings change)

When all issues are resolved, the badge disappears.

Fixing Issues

One-Click Corrections

When a check provides a suggested replacement, you can apply it with a single click on the Correct button. The fix is applied directly to the translation text.

Ignoring Issues

Sometimes a flagged issue is intentional or a false positive. For example, you might deliberately omit a placeholder in a specific language, or a grammar check might not understand a domain-specific term. In these cases, you can Ignore the issue. Ignored issues won't count toward the issue total and won't appear as warnings.

To ignore an issue, click the Ignore button next to it in the QA panel. You can also Unignore it later if needed.

Configuring Check Severity

You can customize which checks are active and their severity at both the project level and the language level.

Project-Level Settings

To configure QA checks for your entire project

  1. Go to Project settings > QA Checks
  2. For each check type, set the severity
    • Warning - the check is active and issues are reported
    • Off - the check is disabled

Currently, only two severity levels are supported: Warning and Off. More severity levels may be added in the future.

Most checks default to Warning. The exceptions are Empty translation, Special character mismatch, Spelling, and Grammar, which default to Off.

Language-Level Overrides

Some checks may not be relevant for all languages. For example, character case checks don't apply to languages without case distinctions, and certain punctuation rules differ across writing systems. Language-level overrides let you fine-tune settings for these cases.

To configure overrides for a specific language

  1. Go to Project settings > QA Checks
  2. Click on the Language overrides section
  3. Select a language and adjust the settings

Language-level settings always take precedence over project-level settings. Changing project settings does not affect languages that already have overrides. You can reset a language back to project defaults at any time.

When QA Checks Run

QA checks run in real time as you type in the translation editor, so you get immediate feedback without saving first. When you save a translation, all enabled checks run again and results are persisted. This also applies to imported translations. The QA badge and issue counts are updated accordingly.

The system is designed to handle all rechecking automatically, so you should never need to trigger a manual recheck under normal circumstances. However, as a last resort, you can manually trigger a full QA recheck for all translations in a project from the translations view using batch operations.

Checks are also automatically re-run when the base language translation changes, a language tag is changed, or branches are merged.

Plural Translations

For translations that use plural forms, QA checks run separately on each plural variant. Issues are reported per variant, so you can see exactly which form has the problem.