mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 17:12:46 +08:00
2404fa7a23
Splits the `ToggleTopicClosed` job into two distinct `OpenTopic` and `CloseTopic` jobs to make the code clearer. The old job cannot be deleted yet because of outstanding sidekiq schedules, so a todo has been added to do so later this year. Also replaced mentions of `topic_status_update` with `topic_timer` in some files, because the `topic_status_update` model is obsolete and replaced by topic timer. Added some shortcut methods for checking if a topic is open/whether a user can change an open topic.
103 lines
3.1 KiB
Ruby
103 lines
3.1 KiB
Ruby
# encoding: UTF-8
|
|
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
describe Topic do
|
|
let(:job_klass) { Jobs::CloseTopic }
|
|
|
|
context 'creating a topic without auto-close' do
|
|
let(:topic) { Fabricate(:topic, category: category) }
|
|
|
|
context 'uncategorized' do
|
|
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([])
|
|
end
|
|
end
|
|
|
|
context 'category without default auto-close' do
|
|
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([])
|
|
end
|
|
end
|
|
|
|
context 'jobs may be queued' do
|
|
before do
|
|
freeze_time
|
|
end
|
|
|
|
context 'category has a default auto-close' do
|
|
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 eq_time(2.hours.from_now)
|
|
|
|
args = job_klass.jobs.last['args'].first
|
|
|
|
expect(args["topic_timer_id"]).to eq(topic.public_topic_timer.id)
|
|
end
|
|
|
|
context 'topic was created by staff user' do
|
|
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 eq_time(2.hours.from_now)
|
|
expect(topic_status_update.user).to eq(Discourse.system_user)
|
|
|
|
args = job_klass.jobs.last['args'].first
|
|
|
|
expect(args["topic_timer_id"]).to eq(topic_status_update.id)
|
|
end
|
|
|
|
context 'topic is closed manually' do
|
|
it 'should remove the schedule to auto-close the topic' do
|
|
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 eq_time(Time.zone.now)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'topic was created by a non-staff user' do
|
|
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
|
|
|
|
expect(topic_status_update.topic).to eq(regular_user_topic)
|
|
expect(topic_status_update.execute_at).to eq_time(2.hours.from_now)
|
|
expect(topic_status_update.user).to eq(Discourse.system_user)
|
|
|
|
args = job_klass.jobs.last['args'].first
|
|
|
|
expect(args["topic_timer_id"]).to eq(topic_status_update.id)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|