mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
TimeWithZone#- added, so that #- can handle a Time or TimeWithZone argument correctly
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@8732 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
parent
c95365a00e
commit
8ef3dfff7a
3 changed files with 9 additions and 0 deletions
|
@ -1,5 +1,7 @@
|
|||
*SVN*
|
||||
|
||||
* TimeWithZone#- added, so that #- can handle a Time or TimeWithZone argument correctly [Geoff Buesing]
|
||||
|
||||
* with_timezone test helper renamed with_env_tz, to distinguish between setting ENV['TZ'] and setting Time.zone in tests [Geoff Buesing]
|
||||
|
||||
* Time#- coerces TimeWithZone argument to a Time instance so that difference in seconds can be calculated. Closes #10914 [Geoff Buesing, yyyc514]
|
||||
|
|
|
@ -106,6 +106,12 @@ module ActiveSupport
|
|||
def <=>(other)
|
||||
utc <=> other
|
||||
end
|
||||
|
||||
# Need to override #- to intercept situation where a Time or Time With Zone object is passed in
|
||||
# Otherwise, just pass on to method missing
|
||||
def -(other)
|
||||
other.acts_like?(:time) ? utc - other : method_missing(:-, other)
|
||||
end
|
||||
|
||||
# A TimeProxy acts like a Time, so just return self
|
||||
def to_time
|
||||
|
|
|
@ -124,6 +124,7 @@ uses_tzinfo 'TimeWithZoneTest' do
|
|||
|
||||
def test_minus_with_time
|
||||
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), TimeZone['UTC'] ) - Time.utc(2000, 1, 1)
|
||||
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), TimeZone['Hawaii'] ) - Time.utc(2000, 1, 1)
|
||||
end
|
||||
|
||||
def test_minus_with_time_with_zone
|
||||
|
|
Loading…
Reference in a new issue