-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Sanitize i18n keys using i18n-tasks gem issue: #3978
i18n-tasks gem helps in managing translations. For now we don't use the tasks in our test pipeline. Added config and test for `api/` and `core/`. Signed-off-by: Shubham Pandey <shubham9411@gmail.com>
- Loading branch information
1 parent
64b9e15
commit 83b5dab
Showing
7 changed files
with
470 additions
and
264 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
# i18n-tasks finds and manages missing and unused translations: https://github.com/glebm/i18n-tasks | ||
|
||
# The "main" locale. | ||
base_locale: en | ||
## All available locales are inferred from the data by default. Alternatively, specify them explicitly: | ||
# locales: [es, fr] | ||
## Reporting locale, default: en. Available: en, ru. | ||
# internal_locale: en | ||
|
||
# Read and write translations. | ||
data: | ||
## Translations are read from the file system. Supported format: YAML, JSON. | ||
## Provide a custom adapter: | ||
# adapter: I18n::Tasks::Data::FileSystem | ||
|
||
# Locale files or `File.find` patterns where translations are read from: | ||
read: | ||
## Default: | ||
# - config/locales/%{locale}.yml | ||
## More files: | ||
# - config/locales/**/*.%{locale}.yml | ||
|
||
# Locale files to write new keys to, based on a list of key pattern => file rules. Matched from top to bottom: | ||
# `i18n-tasks normalize -p` will force move the keys according to these rules | ||
write: | ||
## For example, write devise and simple form keys to their respective files: | ||
# - ['{devise, simple_form}.*', 'config/locales/\1.%{locale}.yml'] | ||
## Catch-all default: | ||
# - config/locales/%{locale}.yml | ||
|
||
# External locale data (e.g. gems). | ||
# This data is not considered unused and is never written to. | ||
external: | ||
## Example (replace %#= with %=): | ||
# - "<%#= %x[bundle info vagrant --path].chomp %>/templates/locales/%{locale}.yml" | ||
|
||
## Specify the router (see Readme for details). Valid values: conservative_router, pattern_router, or a custom class. | ||
# router: conservative_router | ||
|
||
yaml: | ||
write: | ||
# do not wrap lines at 80 characters | ||
line_width: -1 | ||
|
||
## Pretty-print JSON: | ||
# json: | ||
# write: | ||
# indent: ' ' | ||
# space: ' ' | ||
# object_nl: "\n" | ||
# array_nl: "\n" | ||
|
||
# Find translate calls | ||
search: | ||
## Paths or `File.find` patterns to search in: | ||
# paths: | ||
# - app/ | ||
|
||
## Root directories for relative keys resolution. | ||
# relative_roots: | ||
# - app/controllers | ||
# - app/helpers | ||
# - app/mailers | ||
# - app/presenters | ||
# - app/views | ||
|
||
## Files or `File.fnmatch` patterns to exclude from search. Some files are always excluded regardless of this setting: | ||
## %w(*.jpg *.png *.gif *.svg *.ico *.eot *.otf *.ttf *.woff *.woff2 *.pdf *.css *.sass *.scss *.less *.yml *.json) | ||
exclude: | ||
- app/assets/images | ||
- app/assets/fonts | ||
- app/assets/videos | ||
|
||
## Alternatively, the only files or `File.fnmatch patterns` to search in `paths`: | ||
## If specified, this settings takes priority over `exclude`, but `exclude` still applies. | ||
# only: ["*.rb", "*.html.slim"] | ||
|
||
## If `strict` is `false`, guess usages such as t("categories.#{category}.title"). The default is `true`. | ||
# strict: true | ||
|
||
## Multiple scanners can be used. Their results are merged. | ||
## The options specified above are passed down to each scanner. Per-scanner options can be specified as well. | ||
## See this example of a custom scanner: https://github.com/glebm/i18n-tasks/wiki/A-custom-scanner-example | ||
|
||
## Translation Services | ||
# translation: | ||
# # Google Translate | ||
# # Get an API key and set billing info at https://code.google.com/apis/console to use Google Translate | ||
# google_translate_api_key: "AbC-dEf5" | ||
# # DeepL Pro Translate | ||
# # Get an API key and subscription at https://www.deepl.com/pro to use DeepL Pro | ||
# deepl_api_key: "48E92789-57A3-466A-9959-1A1A1A1A1A1A" | ||
|
||
## Do not consider these keys missing: | ||
#ignore_missing: | ||
# - 'number.currency.format.separator' | ||
# - 'errors.messages.{accepted,blank,invalid,too_short,too_long}' | ||
# - '{devise,simple_form}.*' | ||
|
||
## Consider these keys used: | ||
ignore_unused: | ||
# - 'activerecord.attributes.*' | ||
# - '{devise,kaminari,will_paginate}.*' | ||
# - 'simple_form.{yes,no}' | ||
# - 'simple_form.{placeholders,hints,labels}.*' | ||
# - 'simple_form.{error_notification,required}.:' | ||
|
||
## Exclude these keys from the `i18n-tasks eq-base' report: | ||
# ignore_eq_base: | ||
# all: | ||
# - common.ok | ||
# fr,es: | ||
# - common.brand | ||
|
||
## Exclude these keys from the `i18n-tasks check-consistent-interpolations` report: | ||
# ignore_inconsistent_interpolations: | ||
# - 'activerecord.attributes.*' | ||
|
||
## Ignore these keys completely: | ||
# ignore: | ||
# - kaminari.* | ||
|
||
## Sometimes, it isn't possible for i18n-tasks to match the key correctly, | ||
## e.g. in case of a relative key defined in a helper method. | ||
## In these cases you can use the built-in PatternMapper to map patterns to keys, e.g.: | ||
# | ||
# <%# I18n::Tasks.add_scanner 'I18n::Tasks::Scanners::PatternMapper', | ||
# only: %w(*.html.haml *.html.slim), | ||
# patterns: [['= title\b', '.page_title']] %> | ||
# | ||
# The PatternMapper can also match key literals via a special %{key} interpolation, e.g.: | ||
# | ||
# <%# I18n::Tasks.add_scanner 'I18n::Tasks::Scanners::PatternMapper', | ||
# patterns: [['\bSpree\.t[( ]\s*%{key}', 'spree.%{key}']] %> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
# frozen_string_literal: true | ||
|
||
require 'i18n/tasks' | ||
|
||
RSpec.describe I18n do | ||
let(:i18n) { I18n::Tasks::BaseTask.new } | ||
let(:missing_keys) { i18n.missing_keys } | ||
let(:unused_keys) { i18n.unused_keys } | ||
let(:inconsistent_interpolations) { i18n.inconsistent_interpolations } | ||
|
||
it 'does not have missing keys' do | ||
expect(missing_keys).to be_empty, | ||
"Missing #{missing_keys.leaves.count} i18n keys, run `i18n-tasks missing' to show them" | ||
end | ||
|
||
it 'does not have unused keys' do | ||
expect(unused_keys).to be_empty, | ||
"#{unused_keys.leaves.count} unused i18n keys, run `i18n-tasks unused' to show them" | ||
end | ||
|
||
it 'files are normalized' do | ||
non_normalized = i18n.non_normalized_paths | ||
error_message = "The following files need to be normalized:\n" \ | ||
"#{non_normalized.map { |path| " #{path}" }.join("\n")}\n" \ | ||
"Please run `i18n-tasks normalize' to fix" | ||
expect(non_normalized).to be_empty, error_message | ||
end | ||
|
||
it 'does not have inconsistent interpolations' do | ||
error_message = "#{inconsistent_interpolations.leaves.count} i18n keys have inconsistent interpolations.\n" \ | ||
"Run `i18n-tasks check-consistent-interpolations' to show them" | ||
expect(inconsistent_interpolations).to be_empty, error_message | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
# i18n-tasks finds and manages missing and unused translations: https://github.com/glebm/i18n-tasks | ||
|
||
# The "main" locale. | ||
base_locale: en | ||
## All available locales are inferred from the data by default. Alternatively, specify them explicitly: | ||
# locales: [es, fr] | ||
## Reporting locale, default: en. Available: en, ru. | ||
# internal_locale: en | ||
|
||
# Read and write translations. | ||
data: | ||
## Translations are read from the file system. Supported format: YAML, JSON. | ||
## Provide a custom adapter: | ||
# adapter: I18n::Tasks::Data::FileSystem | ||
|
||
# Locale files or `File.find` patterns where translations are read from: | ||
read: | ||
## Default: | ||
# - config/locales/%{locale}.yml | ||
## More files: | ||
# - config/locales/**/*.%{locale}.yml | ||
|
||
# Locale files to write new keys to, based on a list of key pattern => file rules. Matched from top to bottom: | ||
# `i18n-tasks normalize -p` will force move the keys according to these rules | ||
write: | ||
## For example, write devise and simple form keys to their respective files: | ||
# - ['{devise, simple_form}.*', 'config/locales/\1.%{locale}.yml'] | ||
## Catch-all default: | ||
# - config/locales/%{locale}.yml | ||
|
||
# External locale data (e.g. gems). | ||
# This data is not considered unused and is never written to. | ||
external: | ||
## Example (replace %#= with %=): | ||
# - "<%#= %x[bundle info vagrant --path].chomp %>/templates/locales/%{locale}.yml" | ||
|
||
## Specify the router (see Readme for details). Valid values: conservative_router, pattern_router, or a custom class. | ||
# router: conservative_router | ||
|
||
yaml: | ||
write: | ||
# do not wrap lines at 80 characters | ||
line_width: -1 | ||
|
||
## Pretty-print JSON: | ||
# json: | ||
# write: | ||
# indent: ' ' | ||
# space: ' ' | ||
# object_nl: "\n" | ||
# array_nl: "\n" | ||
|
||
# Find translate calls | ||
search: | ||
## Paths or `File.find` patterns to search in: | ||
# paths: | ||
# - app/ | ||
|
||
## Root directories for relative keys resolution. | ||
# relative_roots: | ||
# - app/controllers | ||
# - app/helpers | ||
# - app/mailers | ||
# - app/presenters | ||
# - app/views | ||
|
||
## Files or `File.fnmatch` patterns to exclude from search. Some files are always excluded regardless of this setting: | ||
## %w(*.jpg *.png *.gif *.svg *.ico *.eot *.otf *.ttf *.woff *.woff2 *.pdf *.css *.sass *.scss *.less *.yml *.json) | ||
exclude: | ||
- app/assets/images | ||
- app/assets/fonts | ||
- app/assets/videos | ||
|
||
## Alternatively, the only files or `File.fnmatch patterns` to search in `paths`: | ||
## If specified, this settings takes priority over `exclude`, but `exclude` still applies. | ||
# only: ["*.rb", "*.html.slim"] | ||
|
||
## If `strict` is `false`, guess usages such as t("categories.#{category}.title"). The default is `true`. | ||
# strict: true | ||
|
||
## Multiple scanners can be used. Their results are merged. | ||
## The options specified above are passed down to each scanner. Per-scanner options can be specified as well. | ||
## See this example of a custom scanner: https://github.com/glebm/i18n-tasks/wiki/A-custom-scanner-example | ||
|
||
## Translation Services | ||
# translation: | ||
# # Google Translate | ||
# # Get an API key and set billing info at https://code.google.com/apis/console to use Google Translate | ||
# google_translate_api_key: "AbC-dEf5" | ||
# # DeepL Pro Translate | ||
# # Get an API key and subscription at https://www.deepl.com/pro to use DeepL Pro | ||
# deepl_api_key: "48E92789-57A3-466A-9959-1A1A1A1A1A1A" | ||
|
||
## Do not consider these keys missing: | ||
ignore_missing: | ||
- 'number.currency.format.separator' | ||
# - 'errors.messages.{accepted,blank,invalid,too_short,too_long}' | ||
# - '{devise,simple_form}.*' | ||
|
||
## Consider these keys used: | ||
#ignore_unused: | ||
# - 'activerecord.attributes.*' | ||
# - '{devise,kaminari,will_paginate}.*' | ||
# - 'simple_form.{yes,no}' | ||
# - 'simple_form.{placeholders,hints,labels}.*' | ||
# - 'simple_form.{error_notification,required}.:' | ||
|
||
## Exclude these keys from the `i18n-tasks eq-base' report: | ||
# ignore_eq_base: | ||
# all: | ||
# - common.ok | ||
# fr,es: | ||
# - common.brand | ||
|
||
## Exclude these keys from the `i18n-tasks check-consistent-interpolations` report: | ||
# ignore_inconsistent_interpolations: | ||
# - 'activerecord.attributes.*' | ||
|
||
## Ignore these keys completely: | ||
# ignore: | ||
# - kaminari.* | ||
|
||
## Sometimes, it isn't possible for i18n-tasks to match the key correctly, | ||
## e.g. in case of a relative key defined in a helper method. | ||
## In these cases you can use the built-in PatternMapper to map patterns to keys, e.g.: | ||
# | ||
# <%# I18n::Tasks.add_scanner 'I18n::Tasks::Scanners::PatternMapper', | ||
# only: %w(*.html.haml *.html.slim), | ||
# patterns: [['= title\b', '.page_title']] %> | ||
# | ||
# The PatternMapper can also match key literals via a special %{key} interpolation, e.g.: | ||
# | ||
# <%# I18n::Tasks.add_scanner 'I18n::Tasks::Scanners::PatternMapper', | ||
# patterns: [['\bSpree\.t[( ]\s*%{key}', 'spree.%{key}']] %> |
Oops, something went wrong.