diff options
author | Matt Jankowski <mjankowski@thoughtbot.com> | 2017-04-14 19:12:39 -0400 |
---|---|---|
committer | Eugen <eugen@zeonfederated.com> | 2017-04-15 01:12:39 +0200 |
commit | f5cd1383231af6922dbab4f54b7d29eacfec9d9e (patch) | |
tree | b5fc3c714c4f29dcba644d596495a531c4abb467 /spec/requests | |
parent | 66ea015a017d97ecbd18eb850a033ca0c32e7957 (diff) |
Improve i18n chooser (#1804)
* Add locale spec with failing locale plus region check * Use a more accurate locale when supplied by browser headers Previously we were using a matching option which would use the first locale available which matched the locale portion, even if a region was specified. This changes to first try to find an exact match, and then fall back to the region, and then fall back to the default. * Clean up default_locale method
Diffstat (limited to 'spec/requests')
-rw-r--r-- | spec/requests/localization_spec.rb | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/spec/requests/localization_spec.rb b/spec/requests/localization_spec.rb new file mode 100644 index 000000000..d1b7bdc1d --- /dev/null +++ b/spec/requests/localization_spec.rb @@ -0,0 +1,31 @@ +# frozen_string_literal: true + +require 'rails_helper' + +describe 'Localization' do + it 'uses a specific region when provided' do + headers = { 'Accept-Language' => 'zh-HK' } + + get "/about", headers: headers + expect(response.body).to include( + I18n.t('about.about_mastodon', locale: 'zh-HK') + ) + end + + it 'falls back to a locale when region missing' do + headers = { 'Accept-Language' => 'es-FAKE' } + + get "/about", headers: headers + expect(response.body).to include( + I18n.t('about.about_mastodon', locale: 'es') + ) + end + it 'falls back to english when locale is missing' do + headers = { 'Accept-Language' => '12-FAKE' } + + get "/about", headers: headers + expect(response.body).to include( + I18n.t('about.about_mastodon', locale: 'en') + ) + end +end |