FIX: Preserve PostCreator's created_at resolution (#9140)
PostMover passes to PostCreator a `created_at` that is a `ActiveSupport::WithTimeZone` instance (and also `is_a? Time`). Previously it was always being passed through `Time.zone.parse` so it would lose sub-second information. Now, it takes `Time` input as-is, while still parsing other types.
This commit is contained in:
parent
85e03a7f68
commit
e35bc8bebd
|
@ -494,7 +494,12 @@ class PostCreator
|
||||||
end
|
end
|
||||||
|
|
||||||
post.extract_quoted_post_numbers
|
post.extract_quoted_post_numbers
|
||||||
post.created_at = Time.zone.parse(@opts[:created_at].to_s) if @opts[:created_at].present?
|
|
||||||
|
post.created_at = if @opts[:created_at].is_a?(Time)
|
||||||
|
@opts[:created_at]
|
||||||
|
elsif @opts[:created_at].present?
|
||||||
|
Time.zone.parse(@opts[:created_at].to_s)
|
||||||
|
end
|
||||||
|
|
||||||
if fields = @opts[:custom_fields]
|
if fields = @opts[:custom_fields]
|
||||||
post.custom_fields = fields
|
post.custom_fields = fields
|
||||||
|
|
|
@ -944,24 +944,48 @@ describe PostCreator do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'setting created_at' do
|
context 'setting created_at' do
|
||||||
created_at = 1.week.ago
|
it 'supports Time instances' do
|
||||||
let(:topic) do
|
freeze_time
|
||||||
PostCreator.create(user,
|
|
||||||
raw: 'This is very interesting test post content',
|
post1 = PostCreator.create(user,
|
||||||
title: 'This is a very interesting test post title',
|
raw: 'This is very interesting test post content',
|
||||||
created_at: created_at)
|
title: 'This is a very interesting test post title',
|
||||||
|
created_at: 1.week.ago
|
||||||
|
)
|
||||||
|
topic = post1.topic
|
||||||
|
|
||||||
|
post2 = PostCreator.create(user,
|
||||||
|
raw: 'This is very interesting test post content',
|
||||||
|
topic_id: topic,
|
||||||
|
created_at: 1.week.ago
|
||||||
|
)
|
||||||
|
|
||||||
|
expect(post1.created_at).to be_within(1.second).of(1.week.ago)
|
||||||
|
expect(post2.created_at).to be_within(1.second).of(1.week.ago)
|
||||||
|
expect(topic.created_at).to be_within(1.second).of(1.week.ago)
|
||||||
end
|
end
|
||||||
|
|
||||||
let(:post) do
|
it 'supports strings' do
|
||||||
PostCreator.create(user,
|
freeze_time
|
||||||
raw: 'This is very interesting test post content',
|
|
||||||
topic_id: Topic.last,
|
|
||||||
created_at: created_at)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'acts correctly' do
|
time = Time.zone.parse('2019-09-02')
|
||||||
expect(topic.created_at).to be_within(10.seconds).of(created_at)
|
|
||||||
expect(post.created_at).to be_within(10.seconds).of(created_at)
|
post1 = PostCreator.create(user,
|
||||||
|
raw: 'This is very interesting test post content',
|
||||||
|
title: 'This is a very interesting test post title',
|
||||||
|
created_at: '2019-09-02'
|
||||||
|
)
|
||||||
|
topic = post1.topic
|
||||||
|
|
||||||
|
post2 = PostCreator.create(user,
|
||||||
|
raw: 'This is very interesting test post content',
|
||||||
|
topic_id: topic,
|
||||||
|
created_at: '2019-09-02 00:00:00 UTC'
|
||||||
|
)
|
||||||
|
|
||||||
|
expect(post1.created_at).to be_within(1.second).of(time)
|
||||||
|
expect(post2.created_at).to be_within(1.second).of(time)
|
||||||
|
expect(topic.created_at).to be_within(1.second).of(time)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue