mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 11:42:53 +08:00
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
|
||||
|
||||
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]
|
||||
post.custom_fields = fields
|
||||
|
|
|
@ -944,24 +944,48 @@ describe PostCreator do
|
|||
end
|
||||
|
||||
context 'setting created_at' do
|
||||
created_at = 1.week.ago
|
||||
let(:topic) do
|
||||
PostCreator.create(user,
|
||||
raw: 'This is very interesting test post content',
|
||||
title: 'This is a very interesting test post title',
|
||||
created_at: created_at)
|
||||
it 'supports Time instances' do
|
||||
freeze_time
|
||||
|
||||
post1 = PostCreator.create(user,
|
||||
raw: 'This is very interesting test post content',
|
||||
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
|
||||
|
||||
let(:post) do
|
||||
PostCreator.create(user,
|
||||
raw: 'This is very interesting test post content',
|
||||
topic_id: Topic.last,
|
||||
created_at: created_at)
|
||||
end
|
||||
it 'supports strings' do
|
||||
freeze_time
|
||||
|
||||
it 'acts correctly' do
|
||||
expect(topic.created_at).to be_within(10.seconds).of(created_at)
|
||||
expect(post.created_at).to be_within(10.seconds).of(created_at)
|
||||
time = Time.zone.parse('2019-09-02')
|
||||
|
||||
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
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user