gpt4 book ai didi

ruby-on-rails - 如何在我的规范中使用 Timecop 正确地卡住时间?

转载 作者:行者123 更新时间:2023-11-28 19:40:32 25 4
gpt4 key购买 nike

我正在尝试结合使用 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 等)通常也是一种好的做法。

关于ruby-on-rails - 如何在我的规范中使用 Timecop 正确地卡住时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6838688/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com