Admin settings controller refactor, add specs, cleanup ()

* 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 settings
This commit is contained in:
Matt Jankowski 2017-04-20 11:18:09 -04:00 committed by Eugen
parent 4df26b2621
commit 1ada494bb2
2 changed files with 58 additions and 13 deletions
app/controllers/admin
spec/controllers/admin

View file

@ -2,21 +2,15 @@
module Admin module Admin
class SettingsController < BaseController class SettingsController < BaseController
BOOLEAN_SETTINGS = %w(open_registrations).freeze
def index def index
@settings = Setting.all_as_records @settings = Setting.all_as_records
end end
def update def update
@setting = Setting.where(var: params[:id]).first_or_initialize(var: params[:id]) @setting = Setting.where(var: params[:id]).first_or_initialize(var: params[:id])
value = settings_params[:value] @setting.update(value: value_for_update)
# Special cases
value = value == 'true' if @setting.var == 'open_registrations'
if @setting.value != value
@setting.value = value
@setting.save
end
respond_to do |format| respond_to do |format|
format.html { redirect_to admin_settings_path } format.html { redirect_to admin_settings_path }
@ -29,5 +23,17 @@ module Admin
def settings_params def settings_params
params.require(:setting).permit(:value) params.require(:setting).permit(:value)
end end
def value_for_update
if updating_boolean_setting?
settings_params[:value] == 'true'
else
settings_params[:value]
end
end
def updating_boolean_setting?
BOOLEAN_SETTINGS.include?(params[:id])
end
end end
end end

View file

@ -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