discourse/spec/integration/topic_auto_close_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

108 lines
3.4 KiB
Ruby
Raw Normal View History

# encoding: UTF-8
# frozen_string_literal: true
require 'rails_helper'
describe Topic do
let(:job_klass) { Jobs::ToggleTopicClosed }
context 'creating a topic without auto-close' do
2016-12-13 09:59:38 +08:00
let(:topic) { Fabricate(:topic, category: category) }
context 'uncategorized' do
2016-12-13 09:59:38 +08:00
let(:category) { nil }
it 'should not schedule the topic to auto-close' do
expect(topic.public_topic_timer).to eq(nil)
expect(job_klass.jobs).to eq([])
2016-12-13 09:59:38 +08:00
end
end
context 'category without default auto-close' do
2016-12-13 09:59:38 +08:00
let(:category) { Fabricate(:category, auto_close_hours: nil) }
it 'should not schedule the topic to auto-close' do
expect(topic.public_topic_timer).to eq(nil)
expect(job_klass.jobs).to eq([])
2016-12-13 09:59:38 +08:00
end
end
context 'jobs may be queued' do
before do
freeze_time
end
context 'category has a default auto-close' do
2016-12-13 09:59:38 +08:00
let(:category) { Fabricate(:category, auto_close_hours: 2.0) }
it 'should schedule the topic to auto-close' do
topic
topic_status_update = TopicTimer.last
expect(topic_status_update.topic).to eq(topic)
expect(topic.public_topic_timer.execute_at).to be_within_one_second_of(2.hours.from_now)
args = job_klass.jobs.last['args'].first
expect(args["topic_timer_id"]).to eq(topic.public_topic_timer.id)
expect(args["state"]).to eq(true)
2016-12-13 09:59:38 +08:00
end
context 'topic was created by staff user' do
2016-12-13 09:59:38 +08:00
let(:admin) { Fabricate(:admin) }
let(:staff_topic) { Fabricate(:topic, user: admin, category: category) }
it 'should schedule the topic to auto-close' do
staff_topic
topic_status_update = TopicTimer.last
expect(topic_status_update.topic).to eq(staff_topic)
expect(topic_status_update.execute_at).to be_within_one_second_of(2.hours.from_now)
expect(topic_status_update.user).to eq(admin)
args = job_klass.jobs.last['args'].first
expect(args["topic_timer_id"]).to eq(topic_status_update.id)
expect(args["state"]).to eq(true)
2016-12-13 09:59:38 +08:00
end
context 'topic is closed manually' do
2016-12-13 09:59:38 +08:00
it 'should remove the schedule to auto-close the topic' do
freeze_time
topic_timer_id = staff_topic.public_topic_timer.id
staff_topic.update_status('closed', true, admin)
expect(TopicTimer.with_deleted.find(topic_timer_id).deleted_at)
.to be_within(1.second).of(Time.zone.now)
2016-12-13 09:59:38 +08:00
end
end
end
context 'topic was created by a non-staff user' do
2016-12-13 09:59:38 +08:00
let(:regular_user) { Fabricate(:user) }
let(:regular_user_topic) { Fabricate(:topic, user: regular_user, category: category) }
it 'should schedule the topic to auto-close' do
regular_user_topic
topic_status_update = TopicTimer.last
2016-12-13 09:59:38 +08:00
expect(topic_status_update.topic).to eq(regular_user_topic)
expect(topic_status_update.execute_at).to be_within_one_second_of(2.hours.from_now)
expect(topic_status_update.user).to eq(Discourse.system_user)
args = job_klass.jobs.last['args'].first
2016-12-13 09:59:38 +08:00
expect(args["topic_timer_id"]).to eq(topic_status_update.id)
expect(args["state"]).to eq(true)
2016-12-13 09:59:38 +08:00
end
end
end
end
end
end