Próbuję użyć kombinacji Timecop i kwerendy z Arel gdzie_sql do danych, ale nie wydaje mi się, aby Timecop faktycznie zamrozić czas. Próbowałem już Timecop.freeze i Timecop.freeze (Time.now), które są nieco wyłączone, gdy używam Time.now w mojej specyfikacji.Jak prawidłowo zamrozić czas w/Timecop w mojej specyfikacji?
Czego mi brakuje? Ruby 1.9.2, Rails 3.1.0.rc5
-
error
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')"
modelu
scope :unreleased, lambda { |limit = 4| where('release_date > ?', Time.now).
order('release_date asc').
limit(limit) }
Spec
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
Patrząc na to bliżej , Nie sądzę, że jest to timecop, ale problem w formatach znacznika czasu. Teraz po prostu wymyślić ten kawałek. –