make sure topic specs aren't DST sensitive
This commit is contained in:
parent
f25bcc5067
commit
f618278b42
|
@ -5,6 +5,8 @@ require_dependency 'post_destroyer'
|
||||||
|
|
||||||
describe Topic do
|
describe Topic do
|
||||||
|
|
||||||
|
let(:now) { Time.zone.local(2013,11,20,8,0) }
|
||||||
|
|
||||||
it { should validate_presence_of :title }
|
it { should validate_presence_of :title }
|
||||||
|
|
||||||
it { should rate_limit }
|
it { should rate_limit }
|
||||||
|
@ -922,7 +924,7 @@ describe Topic do
|
||||||
context 'a new topic' do
|
context 'a new topic' do
|
||||||
context 'auto_close_at is set' do
|
context 'auto_close_at is set' do
|
||||||
it 'queues a job to close the topic' do
|
it 'queues a job to close the topic' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
Jobs.expects(:enqueue_at).with(7.hours.from_now, :close_topic, all_of( has_key(:topic_id), has_key(:user_id) ))
|
Jobs.expects(:enqueue_at).with(7.hours.from_now, :close_topic, all_of( has_key(:topic_id), has_key(:user_id) ))
|
||||||
Fabricate(:topic, auto_close_hours: 7, user: Fabricate(:admin))
|
Fabricate(:topic, auto_close_hours: 7, user: Fabricate(:admin))
|
||||||
end
|
end
|
||||||
|
@ -946,16 +948,16 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "ignores the category's default auto-close" do
|
it "ignores the category's default auto-close" do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
Jobs.expects(:enqueue_at).with(7.hours.from_now, :close_topic, all_of( has_key(:topic_id), has_key(:user_id) ))
|
Jobs.expects(:enqueue_at).with(7.hours.from_now, :close_topic, all_of( has_key(:topic_id), has_key(:user_id) ))
|
||||||
Fabricate(:topic, auto_close_hours: 7, user: Fabricate(:admin), category_id: Fabricate(:category, auto_close_hours: 2).id)
|
Fabricate(:topic, auto_close_hours: 7, user: Fabricate(:admin), category_id: Fabricate(:category, auto_close_hours: 2).id)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'sets the time when auto_close timer starts' do
|
it 'sets the time when auto_close timer starts' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
topic = Fabricate(:topic, auto_close_hours: 7, user: Fabricate(:admin))
|
topic = Fabricate(:topic, auto_close_hours: 7, user: Fabricate(:admin))
|
||||||
expect(topic.auto_close_started_at).to eq(Time.zone.now)
|
expect(topic.auto_close_started_at).to eq(now)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -963,7 +965,7 @@ describe Topic do
|
||||||
|
|
||||||
context 'an existing topic' do
|
context 'an existing topic' do
|
||||||
it 'when auto_close_at is set, it queues a job to close the topic' do
|
it 'when auto_close_at is set, it queues a job to close the topic' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
topic = Fabricate(:topic)
|
topic = Fabricate(:topic)
|
||||||
Jobs.expects(:enqueue_at).with(12.hours.from_now, :close_topic, has_entries(topic_id: topic.id, user_id: topic.user_id))
|
Jobs.expects(:enqueue_at).with(12.hours.from_now, :close_topic, has_entries(topic_id: topic.id, user_id: topic.user_id))
|
||||||
topic.auto_close_at = 12.hours.from_now
|
topic.auto_close_at = 12.hours.from_now
|
||||||
|
@ -972,7 +974,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'when auto_close_at and auto_closer_user_id are set, it queues a job to close the topic' do
|
it 'when auto_close_at and auto_closer_user_id are set, it queues a job to close the topic' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
topic = Fabricate(:topic)
|
topic = Fabricate(:topic)
|
||||||
closer = Fabricate(:admin)
|
closer = Fabricate(:admin)
|
||||||
Jobs.expects(:enqueue_at).with(12.hours.from_now, :close_topic, has_entries(topic_id: topic.id, user_id: closer.id))
|
Jobs.expects(:enqueue_at).with(12.hours.from_now, :close_topic, has_entries(topic_id: topic.id, user_id: closer.id))
|
||||||
|
@ -992,7 +994,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'when auto_close_user is removed, it updates the job' do
|
it 'when auto_close_user is removed, it updates the job' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
Jobs.stubs(:enqueue_at).with(1.day.from_now, :close_topic, anything).returns(true)
|
Jobs.stubs(:enqueue_at).with(1.day.from_now, :close_topic, anything).returns(true)
|
||||||
topic = Fabricate(:topic, auto_close_at: 1.day.from_now, auto_close_user: Fabricate(:admin))
|
topic = Fabricate(:topic, auto_close_at: 1.day.from_now, auto_close_user: Fabricate(:admin))
|
||||||
Jobs.expects(:cancel_scheduled_job).with(:close_topic, {topic_id: topic.id})
|
Jobs.expects(:cancel_scheduled_job).with(:close_topic, {topic_id: topic.id})
|
||||||
|
@ -1003,7 +1005,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'when auto_close_at value is changed, it reschedules the job' do
|
it 'when auto_close_at value is changed, it reschedules the job' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
Jobs.stubs(:enqueue_at).returns(true)
|
Jobs.stubs(:enqueue_at).returns(true)
|
||||||
topic = Fabricate(:topic, auto_close_at: 1.day.from_now)
|
topic = Fabricate(:topic, auto_close_at: 1.day.from_now)
|
||||||
Jobs.expects(:cancel_scheduled_job).with(:close_topic, {topic_id: topic.id})
|
Jobs.expects(:cancel_scheduled_job).with(:close_topic, {topic_id: topic.id})
|
||||||
|
@ -1014,7 +1016,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'when auto_close_user_id is changed, it updates the job' do
|
it 'when auto_close_user_id is changed, it updates the job' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
admin = Fabricate(:admin)
|
admin = Fabricate(:admin)
|
||||||
Jobs.stubs(:enqueue_at).returns(true)
|
Jobs.stubs(:enqueue_at).returns(true)
|
||||||
topic = Fabricate(:topic, auto_close_at: 1.day.from_now)
|
topic = Fabricate(:topic, auto_close_at: 1.day.from_now)
|
||||||
|
@ -1026,7 +1028,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'when auto_close_at and auto_close_user_id are not changed, it should not schedule another CloseTopic job' do
|
it 'when auto_close_at and auto_close_user_id are not changed, it should not schedule another CloseTopic job' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
Jobs.expects(:enqueue_at).with(1.day.from_now, :close_topic, has_key(:topic_id)).once.returns(true)
|
Jobs.expects(:enqueue_at).with(1.day.from_now, :close_topic, has_key(:topic_id)).once.returns(true)
|
||||||
Jobs.expects(:cancel_scheduled_job).never
|
Jobs.expects(:cancel_scheduled_job).never
|
||||||
topic = Fabricate(:topic, auto_close_at: 1.day.from_now)
|
topic = Fabricate(:topic, auto_close_at: 1.day.from_now)
|
||||||
|
@ -1036,7 +1038,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "ignores the category's default auto-close" do
|
it "ignores the category's default auto-close" do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
mod = Fabricate(:moderator)
|
mod = Fabricate(:moderator)
|
||||||
# NOTE, only moderators can auto-close, if missing system user is used
|
# NOTE, only moderators can auto-close, if missing system user is used
|
||||||
topic = Fabricate(:topic, category: Fabricate(:category, auto_close_hours: 14), user: mod)
|
topic = Fabricate(:topic, category: Fabricate(:category, auto_close_hours: 14), user: mod)
|
||||||
|
@ -1062,7 +1064,7 @@ describe Topic do
|
||||||
subject(:topic) { Fabricate.build(:topic) }
|
subject(:topic) { Fabricate.build(:topic) }
|
||||||
|
|
||||||
it 'can take a number' do
|
it 'can take a number' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
topic.auto_close_hours = 2
|
topic.auto_close_hours = 2
|
||||||
topic.auto_close_at.should be_within_one_second_of(2.hours.from_now)
|
topic.auto_close_at.should be_within_one_second_of(2.hours.from_now)
|
||||||
end
|
end
|
||||||
|
@ -1078,7 +1080,6 @@ describe Topic do
|
||||||
let(:topic) { Fabricate.build(:topic) }
|
let(:topic) { Fabricate.build(:topic) }
|
||||||
let(:closing_topic) { Fabricate.build(:topic, auto_close_hours: 5) }
|
let(:closing_topic) { Fabricate.build(:topic, auto_close_hours: 5) }
|
||||||
let(:admin) { Fabricate.build(:user, id: 123) }
|
let(:admin) { Fabricate.build(:user, id: 123) }
|
||||||
let(:now) { Time.zone.local(2013,11,20,8,0) }
|
|
||||||
|
|
||||||
before { Discourse.stubs(:system_user).returns(admin) }
|
before { Discourse.stubs(:system_user).returns(admin) }
|
||||||
|
|
||||||
|
@ -1164,7 +1165,7 @@ describe Topic do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'updates auto_close_at if it was already set to close' do
|
it 'updates auto_close_at if it was already set to close' do
|
||||||
Timecop.freeze(Time.zone.now) do
|
Timecop.freeze(now) do
|
||||||
closing_topic.set_auto_close(48)
|
closing_topic.set_auto_close(48)
|
||||||
expect(closing_topic.auto_close_at).to eq(2.days.from_now)
|
expect(closing_topic.auto_close_at).to eq(2.days.from_now)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue