diff options
author | alpaca-tc <alpaca-tc@alpaca.tc> | 2017-04-25 22:06:41 +0900 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-04-25 15:06:41 +0200 |
commit | 9317ec8eb185659b687dec2ba84c3f7463d7b61d (patch) | |
tree | 462b08305a4fa45d07c59e8e47853a74b3cda632 /spec | |
parent | 1b9447853bb3381bb9f43b60fdd9cab41e92b53c (diff) |
Localize with i18n for Devise::FailureApp (#2309)
This PR fixes I18n.locale for rake middlewares. Mastodon uses Devise that depends on Warden. Warden::Manager can be found in rake middleware. It is outside of the controller. In the case of authentication failed, warden calls throw(:warden). At the time Warden::Manager delegates request to failure_app to generate response and flash[:alert] after catching it. Unfortunately, I18n.locale is already reset then because I18n.with_locale is enabled only inside the controller. If we used I18n.locale=, Devise::FailureApp could get the current locale.
Diffstat (limited to 'spec')
-rw-r--r-- | spec/controllers/auth/sessions_controller_spec.rb | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/spec/controllers/auth/sessions_controller_spec.rb b/spec/controllers/auth/sessions_controller_spec.rb index 0ec0b8f2f..2b68b4c5a 100644 --- a/spec/controllers/auth/sessions_controller_spec.rb +++ b/spec/controllers/auth/sessions_controller_spec.rb @@ -49,6 +49,20 @@ RSpec.describe Auth::SessionsController, type: :controller do expect(controller.current_user).to be_nil end end + + context 'using an unconfirmed password' do + before do + request.headers['Accept-Language'] = accept_language + post :create, params: { user: { email: unconfirmed_user.email, password: unconfirmed_user.password } } + end + + let(:unconfirmed_user) { user.tap { |u| u.update!(confirmed_at: nil) } } + let(:accept_language) { 'fr' } + + it 'shows a translated login error' do + expect(flash[:alert]).to eq(I18n.t('devise.failure.unconfirmed', locale: accept_language)) + end + end end context 'using two-factor authentication' do |