logo

mastofe

My custom branche(s) on git.pleroma.social/pleroma/mastofe
commit: d87ee1167e0f11d94a20e70e9228a3398e202bc8
parent: 64e1d510259d784c1103d9ff2c738f5e2ba1a31d
Author: saturday06 <dyob@lunaport.net>
Date:   Mon, 17 Apr 2017 17:29:08 +0900

Assign user locale on signup (#1982)


Diffstat:

Mapp/controllers/auth/registrations_controller.rb1+
Mspec/controllers/auth/registrations_controller_spec.rb7++++++-
2 files changed, 7 insertions(+), 1 deletion(-)

diff --git a/app/controllers/auth/registrations_controller.rb b/app/controllers/auth/registrations_controller.rb @@ -10,6 +10,7 @@ class Auth::RegistrationsController < Devise::RegistrationsController def build_resource(hash = nil) super(hash) + resource.locale = I18n.locale resource.build_account if resource.account.nil? end diff --git a/spec/controllers/auth/registrations_controller_spec.rb b/spec/controllers/auth/registrations_controller_spec.rb @@ -16,9 +16,12 @@ RSpec.describe Auth::RegistrationsController, type: :controller do end describe 'POST #create' do + let(:accept_language) { Rails.application.config.i18n.available_locales.sample.to_s } + before do Setting.open_registrations = true request.env["devise.mapping"] = Devise.mappings[:user] + request.headers["Accept-Language"] = accept_language post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678' } } end @@ -27,7 +30,9 @@ RSpec.describe Auth::RegistrationsController, type: :controller do end it 'creates user' do - expect(User.find_by(email: 'test@example.com')).to_not be_nil + user = User.find_by(email: 'test@example.com') + expect(user).to_not be_nil + expect(user.locale).to eq(accept_language) end end end