mirror of
https://github.com/discourse/discourse.git
synced 2024-11-30 13:45:59 +08:00
493d437e79
* Remove outdated option
04078317ba
* Use the non-globally exposed RSpec syntax
https://github.com/rspec/rspec-core/pull/2803
* Use the non-globally exposed RSpec syntax, cont
https://github.com/rspec/rspec-core/pull/2803
* Comply to strict predicate matchers
See:
- https://github.com/rspec/rspec-expectations/pull/1195
- https://github.com/rspec/rspec-expectations/pull/1196
- https://github.com/rspec/rspec-expectations/pull/1277
40 lines
1.3 KiB
Ruby
40 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe Jobs::EnableBootstrapMode do
|
|
|
|
describe '.execute' do
|
|
fab!(:admin) { Fabricate(:admin) }
|
|
|
|
before do
|
|
SiteSetting.bootstrap_mode_enabled = false
|
|
end
|
|
|
|
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
|