私はTimecopの組み合わせを使用してデータにwhere_sqlを照会しようとしていますが、実際に時間を止めるためにTimecopを取得することはできません。 Timecop.freezeとTimecop.freeze(Time.now)を試してみました。どちらも、私の仕様にTime.nowを使用しているときは少しオフになっています。仕様でTimecopを使って時間を正しく凍結させる方法はありますか?
私には何が欠けていますか? 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
タイムコードだとは思えませんが、タイムスタンプ形式の問題です。今すぐその部分を見つけてください。 –