我试图结合使用Timecop和查询arel where_sql到数据,但是我似乎无法让Timecop真正冻结时间。我已经尝试过Timecop.freeze和Timecop.freeze(Time.now),在我的规格中使用Time.now时,两者都略有关闭。

我想念什么? Ruby 1.9.2,Rails 3.1.0.rc5

-

错误

Failure/Error: Game.unreleased.arel.where_sql.should eq("WHERE (release_date > '#{Time.now}')")


     expected "WHERE (release_date > '0000-01-01 00:00:00 -0500')"
     got "WHERE (release_date > '0000-01-01 05:00:00.000000')"


模型

scope :unreleased, lambda { |limit = 4| where('release_date > ?', Time.now).
                                        order('release_date asc').
                                        limit(limit) }


规格

it "should retrieve games with a release date later than today" do
  Timecop.freeze
  Game.unreleased.arel.where_sql.should eq("WHERE (release_date > '#{Time.now}')")
end

最佳答案

我在规格中使用timecop总是像这样:

Timecop.travel(Time.zone.local(2010, 6, 1, 13, 0, 0)) do
  .. time sensitive spec here ..
end


在Rails应用程序中处理时间时,通常也建议使用Time.zone代理(Time.zone.now,Time.zone.utc,Time.zone.local等)。

10-02 21:22