Admin settings controller refactor, add specs, cleanup (#2225)
* Add render_views for admin/settings spec * Add coverage for admin/settings#update * Add coverage for admin/settings typecasting open_registrations setting * Simplify how admin/settings finds the value for updating * Rely on activerecord to not update a value that hasnt changed * Add coverage for non-existent setting * Use a constant for boolean settingsmaster
parent
4df26b2621
commit
1ada494bb2
@ -1,14 +1,53 @@ |
|||||||
require 'rails_helper' |
require 'rails_helper' |
||||||
|
|
||||||
RSpec.describe Admin::SettingsController, type: :controller do |
RSpec.describe Admin::SettingsController, type: :controller do |
||||||
describe 'GET #index' do |
render_views |
||||||
|
|
||||||
|
describe 'When signed in as an admin' do |
||||||
before do |
before do |
||||||
sign_in Fabricate(:user, admin: true), scope: :user |
sign_in Fabricate(:user, admin: true), scope: :user |
||||||
end |
end |
||||||
|
|
||||||
it 'returns http success' do |
describe 'GET #index' do |
||||||
get :index |
it 'returns http success' do |
||||||
expect(response).to have_http_status(:success) |
get :index |
||||||
|
|
||||||
|
expect(response).to have_http_status(:success) |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
describe 'PUT #update' do |
||||||
|
|
||||||
|
describe 'for a record that doesnt exist' do |
||||||
|
after do |
||||||
|
Setting.new_setting_key = nil |
||||||
|
end |
||||||
|
|
||||||
|
it 'creates a settings value that didnt exist before' do |
||||||
|
expect(Setting.new_setting_key).to be_nil |
||||||
|
|
||||||
|
patch :update, params: { id: 'new_setting_key', setting: { value: 'New key value' } } |
||||||
|
|
||||||
|
expect(response).to redirect_to(admin_settings_path) |
||||||
|
expect(Setting.new_setting_key).to eq 'New key value' |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
it 'updates a settings value' do |
||||||
|
Setting.site_title = 'Original' |
||||||
|
patch :update, params: { id: 'site_title', setting: { value: 'New title' } } |
||||||
|
|
||||||
|
expect(response).to redirect_to(admin_settings_path) |
||||||
|
expect(Setting.site_title).to eq 'New title' |
||||||
|
end |
||||||
|
|
||||||
|
it 'typecasts open_registrations to boolean' do |
||||||
|
Setting.open_registrations = false |
||||||
|
patch :update, params: { id: 'open_registrations', setting: { value: 'true' } } |
||||||
|
|
||||||
|
expect(response).to redirect_to(admin_settings_path) |
||||||
|
expect(Setting.open_registrations).to eq true |
||||||
|
end |
||||||
end |
end |
||||||
end |
end |
||||||
end |
end |
||||||
|
Loading…
Reference in new issue