我尝试使用Timecop和查询数据的区域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发布于 2011-07-27 11:43:13
我在规范中对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等)也是一个很好的实践。
发布于 2013-04-17 03:04:15
当我运行以下代码时,我在使用RSpec的expect语法运行Timecop时遇到了问题:
it "updates :completed_at" do
Timecop.freeze
expect(@task.completed_at).to eq(Time.zone.now)
end时间不匹配的地方。为了解决这个问题,我在before子句中放入了Timecop.freeze。
(我知道这个问题由来已久,RSpec的expect语法也不存在,但我认为将Timecop.freeze添加到before块或子句中可能会帮助那些有相同问题的人。当然,这看起来不像是问了一个新的问题,然后回答它是值得的,因为我的问题与上面的问题非常非常相似。)
发布于 2016-06-20 18:26:39
旅行到日期并包含TimeHelpers,例如:
include ActiveSupport::Testing::TimeHelpers
let!(:archived_date) { Time.zone.now }
travel_to(archived_date) do
expect(OrderService.getOrder(some_old_order).archived_at).to eq Time.zone.now
endhttps://stackoverflow.com/questions/6838688
复制相似问题