From aec26ad2f01d6aa4b590878658f98fad38650e41 Mon Sep 17 00:00:00 2001 From: Jarek Radosz Date: Tue, 10 Mar 2020 15:35:40 +0100 Subject: [PATCH] FIX: Preserve TopicCreator's timestamp resolution (#9158) Continuation of #9140 (e35bc8b). It's the last piece required for #9141. --- lib/topic_creator.rb | 12 +++++++++-- spec/components/topic_creator_spec.rb | 30 ++++++++++++++++++++++++++- 2 files changed, 39 insertions(+), 3 deletions(-) diff --git a/lib/topic_creator.rb b/lib/topic_creator.rb index 654fc716f4b..41558784f34 100644 --- a/lib/topic_creator.rb +++ b/lib/topic_creator.rb @@ -118,9 +118,9 @@ class TopicCreator topic_params[:category_id] = category.id if category.present? - topic_params[:created_at] = Time.zone.parse(@opts[:created_at].to_s) if @opts[:created_at].present? + topic_params[:created_at] = convert_time(@opts[:created_at]) if @opts[:created_at].present? - topic_params[:pinned_at] = Time.zone.parse(@opts[:pinned_at].to_s) if @opts[:pinned_at].present? + topic_params[:pinned_at] = convert_time(@opts[:pinned_at]) if @opts[:pinned_at].present? topic_params[:pinned_globally] = @opts[:pinned_globally] if @opts[:pinned_globally].present? if SiteSetting.topic_featured_link_enabled && @opts[:featured_link].present? && @guardian.can_edit_featured_link?(topic_params[:category_id]) @@ -130,6 +130,14 @@ class TopicCreator topic_params end + def convert_time(timestamp) + if timestamp.is_a?(Time) + timestamp + else + Time.zone.parse(timestamp.to_s) + end + end + def find_category @category ||= begin # PM can't have a category diff --git a/spec/components/topic_creator_spec.rb b/spec/components/topic_creator_spec.rb index 36a8717b9ad..d13d48c3f0d 100644 --- a/spec/components/topic_creator_spec.rb +++ b/spec/components/topic_creator_spec.rb @@ -3,7 +3,6 @@ require 'rails_helper' describe TopicCreator do - fab!(:user) { Fabricate(:user, trust_level: TrustLevel[2]) } fab!(:moderator) { Fabricate(:moderator) } fab!(:admin) { Fabricate(:admin) } @@ -237,5 +236,34 @@ describe TopicCreator do end end end + + context 'setting timestamps' do + it 'supports Time instances' do + freeze_time + + topic = TopicCreator.create(user, Guardian.new(user), valid_attrs.merge( + created_at: 1.week.ago, + pinned_at: 3.days.ago + )) + + expect(topic.created_at).to be_within(1.second).of(1.week.ago) + expect(topic.pinned_at).to be_within(1.second).of(3.days.ago) + end + + it 'supports strings' do + freeze_time + + time1 = Time.zone.parse('2019-09-02') + time2 = Time.zone.parse('2020-03-10 15:17') + + topic = TopicCreator.create(user, Guardian.new(user), valid_attrs.merge( + created_at: '2019-09-02', + pinned_at: '2020-03-10 15:17' + )) + + expect(topic.created_at).to be_within(1.second).of(time1) + expect(topic.pinned_at).to be_within(1.second).of(time2) + end + end end end