about summary refs log tree commit diff
path: root/spec/requests
diff options
context:
space:
mode:
authorMatt Jankowski <mjankowski@thoughtbot.com>2017-04-14 19:12:39 -0400
committerEugen <eugen@zeonfederated.com>2017-04-15 01:12:39 +0200
commitf5cd1383231af6922dbab4f54b7d29eacfec9d9e (patch)
treeb5fc3c714c4f29dcba644d596495a531c4abb467 /spec/requests
parent66ea015a017d97ecbd18eb850a033ca0c32e7957 (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.rb31
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