commit: 55e1e12b7d673aece3cf015360af9fb4252dd7e5
parent: 6e27e08cb435d170a8d37dd17d3c2442e9ad34ce
Author: Matt Jankowski <mjankowski@thoughtbot.com>
Date: Sun, 23 Apr 2017 13:09:52 -0400
Ensure i18n matches options (#2358)
* Add failing spec showing that human_locales does not match what i18n knows about
* Add missing `ar` key for arabic to human locales
* Remove duplicate `id` key from available locales
* Sort keys in human locales list
* Add spec for human_locale helper
Diffstat:
3 files changed, 28 insertions(+), 6 deletions(-)
diff --git a/app/helpers/settings_helper.rb b/app/helpers/settings_helper.rb
@@ -3,29 +3,30 @@
module SettingsHelper
HUMAN_LOCALES = {
en: 'English',
+ ar: 'عربى',
+ bg: 'Български',
de: 'Deutsch',
- es: 'Español',
eo: 'Esperanto',
+ es: 'Español',
+ fi: 'Suomi',
fr: 'Français',
hr: 'Hrvatski',
hu: 'Magyar',
+ id: 'Bahasa Indonesia',
io: 'Ido',
it: 'Italiano',
+ ja: '日本語',
nl: 'Nederlands',
no: 'Norsk',
oc: 'Occitan',
pl: 'Polszczyzna',
pt: 'Português',
'pt-BR': 'Português do Brasil',
- fi: 'Suomi',
ru: 'Русский',
uk: 'Українська',
- ja: '日本語',
'zh-CN': '简体中文',
'zh-HK': '繁體中文(香港)',
'zh-TW': '繁體中文(臺灣)',
- bg: 'Български',
- id: 'Bahasa Indonesia',
}.freeze
def human_locale(locale)
diff --git a/config/application.rb b/config/application.rb
@@ -35,7 +35,6 @@ module Mastodon
:fi,
:fr,
:hr,
- :id,
:hu,
:id,
:io,
diff --git a/spec/helpers/settings_helper_spec.rb b/spec/helpers/settings_helper_spec.rb
@@ -0,0 +1,22 @@
+# frozen_string_literal: true
+
+require 'rails_helper'
+
+describe SettingsHelper do
+ describe 'the HUMAN_LOCALES constant' do
+ it 'has the same number of keys as I18n locales exist' do
+ options = I18n.available_locales
+
+ expect(described_class::HUMAN_LOCALES.keys).to eq(options)
+ end
+ end
+
+ describe 'human_locale' do
+ it 'finds the human readable local description from a key' do
+ # Ensure the value is as we expect
+ expect(described_class::HUMAN_LOCALES[:en]).to eq('English')
+
+ expect(helper.human_locale(:en)).to eq('English')
+ end
+ end
+end