mirror of
https://github.com/discourse/discourse.git
synced 2024-12-18 21:05:58 +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
50 lines
1.4 KiB
Ruby
50 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
||
|
||
RSpec.describe Jobs::RemoveBanner do
|
||
fab!(:topic) { Fabricate(:topic) }
|
||
fab!(:user) { topic.user }
|
||
|
||
context 'topic is not bannered until' do
|
||
it 'doesn’t enqueue a future job to remove it' do
|
||
expect do
|
||
topic.make_banner!(user)
|
||
end.not_to change { Jobs::RemoveBanner.jobs.size }
|
||
end
|
||
end
|
||
|
||
context 'topic is bannered until' do
|
||
context 'bannered_until is a valid date' do
|
||
it 'enqueues a future job to remove it' do
|
||
bannered_until = 5.days.from_now
|
||
|
||
expect(topic.archetype).to eq(Archetype.default)
|
||
|
||
expect do
|
||
topic.make_banner!(user, bannered_until.to_s)
|
||
end.to change { Jobs::RemoveBanner.jobs.size }.by(1)
|
||
|
||
topic.reload
|
||
expect(topic.archetype).to eq(Archetype.banner)
|
||
|
||
job = Jobs::RemoveBanner.jobs[0]
|
||
expect(Time.at(job['at'])).to be_within_one_minute_of(bannered_until)
|
||
expect(job['args'][0]['topic_id']).to eq(topic.id)
|
||
|
||
job['class'].constantize.new.perform(*job['args'])
|
||
topic.reload
|
||
expect(topic.archetype).to eq(Archetype.default)
|
||
end
|
||
end
|
||
|
||
context 'bannered_until is an invalid date' do
|
||
it 'doesn’t enqueue a future job to remove it' do
|
||
expect do
|
||
expect do
|
||
topic.make_banner!(user, 'xxx')
|
||
end.to raise_error(Discourse::InvalidParameters)
|
||
end.not_to change { Jobs::RemoveBanner.jobs.size }
|
||
end
|
||
end
|
||
end
|
||
end
|