make sure topic specs aren't DST sensitive

This commit is contained in:
Régis Hanol 2014-03-07 11:38:24 +01:00
parent f25bcc5067
commit f618278b42
1 changed files with 15 additions and 14 deletions

View File

@ -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