discourse/spec/jobs/enable_bootstrap_mode_spec.rb
Daniel Waterworth 6e161d3e75
DEV: Allow fab! without block (#24314)
The most common thing that we do with fab! is:

    fab!(:thing) { Fabricate(:thing) }

This commit adds a shorthand for this which is just simply:

    fab!(:thing)

i.e. If you omit the block, then, by default, you'll get a `Fabricate`d object using the fabricator of the same name.
2023-11-09 16:47:59 -06:00

39 lines
1.3 KiB
Ruby

# frozen_string_literal: true
RSpec.describe Jobs::EnableBootstrapMode do
describe ".execute" do
fab!(:admin)
before { SiteSetting.bootstrap_mode_enabled = false }
it "raises an error when user_id is missing" do
expect { Jobs::EnableBootstrapMode.new.execute({}) }.to raise_error(
Discourse::InvalidParameters,
)
end
it "does not execute if bootstrap mode is already enabled" do
SiteSetting.bootstrap_mode_enabled = true
StaffActionLogger.any_instance.expects(:log_site_setting_change).never
Jobs::EnableBootstrapMode.new.execute(user_id: admin.id)
end
it "does not turn on bootstrap mode if first admin already exists" do
first_admin = Fabricate(:admin)
StaffActionLogger.any_instance.expects(:log_site_setting_change).never
Jobs::EnableBootstrapMode.new.execute(user_id: admin.id)
end
it "does not amend setting that is not in default state" do
SiteSetting.default_trust_level = TrustLevel[3]
StaffActionLogger.any_instance.expects(:log_site_setting_change).twice
Jobs::EnableBootstrapMode.new.execute(user_id: admin.id)
end
it "successfully turns on bootstrap mode" do
StaffActionLogger.any_instance.expects(:log_site_setting_change).times(3)
Jobs::EnableBootstrapMode.new.execute(user_id: admin.id)
end
end
end