2024-06-14 06:07:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2024-08-28 08:54:10 -04:00
|
|
|
RSpec.describe UpdateSiteSetting do
|
|
|
|
subject(:result) { described_class.call(params) }
|
|
|
|
|
|
|
|
describe described_class::Contract, type: :model do
|
|
|
|
subject(:contract) { described_class.new }
|
2024-06-14 06:07:27 -04:00
|
|
|
|
2024-08-28 08:54:10 -04:00
|
|
|
it { is_expected.to validate_presence_of :setting_name }
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
|
2024-08-28 08:54:10 -04:00
|
|
|
fab!(:admin)
|
|
|
|
let(:params) { { setting_name:, new_value:, guardian:, allow_changing_hidden: } }
|
|
|
|
let(:setting_name) { :title }
|
|
|
|
let(:new_value) { "blah whatever" }
|
|
|
|
let(:guardian) { admin.guardian }
|
|
|
|
let(:allow_changing_hidden) { false }
|
|
|
|
|
2024-06-14 06:07:27 -04:00
|
|
|
context "when setting_name is blank" do
|
2024-08-28 08:54:10 -04:00
|
|
|
let(:setting_name) { nil }
|
2024-06-14 06:07:27 -04:00
|
|
|
|
2024-08-28 08:54:10 -04:00
|
|
|
it { is_expected.to fail_a_contract }
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "when a non-admin user tries to change a setting" do
|
2024-08-28 08:54:10 -04:00
|
|
|
let(:guardian) { Guardian.new }
|
|
|
|
|
|
|
|
it { is_expected.to fail_a_policy(:current_user_is_admin) }
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "when the user changes a hidden setting" do
|
2024-08-28 08:54:10 -04:00
|
|
|
let(:setting_name) { :max_category_nesting }
|
|
|
|
let(:new_value) { 3 }
|
|
|
|
|
2024-06-14 06:07:27 -04:00
|
|
|
context "when allow_changing_hidden is false" do
|
2024-08-28 08:54:10 -04:00
|
|
|
it { is_expected.to fail_a_policy(:setting_is_visible) }
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "when allow_changing_hidden is true" do
|
2024-08-28 08:54:10 -04:00
|
|
|
let(:allow_changing_hidden) { true }
|
|
|
|
|
|
|
|
it { is_expected.to run_successfully }
|
|
|
|
|
2024-06-14 06:07:27 -04:00
|
|
|
it "updates the specified setting" do
|
2024-08-28 08:54:10 -04:00
|
|
|
expect { result }.to change { SiteSetting.max_category_nesting }.to(3)
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the user changes a visible setting" do
|
2024-08-28 08:54:10 -04:00
|
|
|
let(:new_value) { "hello this is title" }
|
2024-06-14 06:07:27 -04:00
|
|
|
|
2024-08-28 08:54:10 -04:00
|
|
|
it { is_expected.to run_successfully }
|
2024-06-14 06:07:27 -04:00
|
|
|
|
2024-08-28 08:54:10 -04:00
|
|
|
it "updates the specified setting" do
|
|
|
|
expect { result }.to change { SiteSetting.title }.to(new_value)
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "creates an entry in the staff action logs" do
|
2024-08-28 08:54:10 -04:00
|
|
|
expect { result }.to change {
|
|
|
|
UserHistory.where(action: UserHistory.actions[:change_site_setting], subject: "title").count
|
2024-06-14 06:07:27 -04:00
|
|
|
}.by(1)
|
|
|
|
end
|
2024-08-28 08:54:10 -04:00
|
|
|
|
|
|
|
context "when value needs cleanup" do
|
|
|
|
let(:setting_name) { :max_image_size_kb }
|
|
|
|
let(:new_value) { "8zf843" }
|
|
|
|
|
|
|
|
it "cleans up the new setting value before using it" do
|
|
|
|
expect { result }.to change { SiteSetting.max_image_size_kb }.to(8843)
|
|
|
|
end
|
|
|
|
end
|
2024-06-14 06:07:27 -04:00
|
|
|
end
|
|
|
|
end
|