Eri*_* M. 16 testing rspec ruby-on-rails ruby-on-rails-3
我试图使用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')"
Run Code Online (Sandbox Code Playgroud)
模型
scope :unreleased, lambda { |limit = 4| where('release_date > ?', Time.now).
order('release_date asc').
limit(limit) }
Run Code Online (Sandbox Code Playgroud)
规范
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
Run Code Online (Sandbox Code Playgroud)
Jam*_*aly 28
我在规格中对timecop的使用总是如下所示:
Timecop.travel(Time.zone.local(2010, 6, 1, 13, 0, 0)) do
.. time sensitive spec here ..
end
Run Code Online (Sandbox Code Playgroud)
在rails应用程序中处理时间时,使用Time.zone代理(Time.zone.now,Time.zone.utc,Time.zone.local等)通常也是一种好习惯.
expect我在运行时遇到了使用 RSpec 语法运行 Timecop 的问题:
it "updates :completed_at" do
Timecop.freeze
expect(@task.completed_at).to eq(Time.zone.now)
end
Run Code Online (Sandbox Code Playgroud)
时代不匹配的地方。为了解决这个问题,我添加Timecop.freeze了一个before子句。
(我意识到这个问题很旧,并且 RSpec 的expect语法不存在,但我认为添加Timecop.freeze到before块或子句可能会帮助那些在原始问题中提到相同问题的人。当然,这似乎不像提出一个新问题回答这个问题是值得的,因为我的问题与上面的问题非常相似。)
| 归档时间: |
|
| 查看次数: |
15218 次 |
| 最近记录: |