forked from mirrors/catstodon
9566893cc9
* Add render_views in more places * Delegate methods from account to user with allow nil true, so that admin accounts show view renders when missing a user * Use actual account instances in authorize follow controller spec
47 lines
1.3 KiB
Ruby
47 lines
1.3 KiB
Ruby
require 'rails_helper'
|
|
|
|
describe Settings::PreferencesController do
|
|
render_views
|
|
|
|
let(:user) { Fabricate(:user) }
|
|
|
|
before do
|
|
sign_in user, scope: :user
|
|
end
|
|
|
|
describe 'GET #show' do
|
|
it 'returns http success' do
|
|
get :show
|
|
expect(response).to have_http_status(:success)
|
|
end
|
|
end
|
|
|
|
describe 'PUT #update' do
|
|
it 'updates the user record' do
|
|
put :update, params: { user: { locale: 'en' } }
|
|
|
|
expect(response).to redirect_to(settings_preferences_path)
|
|
expect(user.reload.locale).to eq 'en'
|
|
end
|
|
|
|
it 'updates user settings' do
|
|
user.settings['boost_modal'] = false
|
|
user.settings['notification_emails'] = user.settings['notification_emails'].merge('follow' => false)
|
|
user.settings['interactions'] = user.settings['interactions'].merge('must_be_follower' => true)
|
|
|
|
put :update, params: {
|
|
user: {
|
|
setting_boost_modal: '1',
|
|
notification_emails: { follow: '1' },
|
|
interactions: { must_be_follower: '0' },
|
|
}
|
|
}
|
|
|
|
expect(response).to redirect_to(settings_preferences_path)
|
|
user.reload
|
|
expect(user.settings['boost_modal']).to be true
|
|
expect(user.settings['notification_emails']['follow']).to be true
|
|
expect(user.settings['interactions']['must_be_follower']).to be false
|
|
end
|
|
end
|
|
end
|