diff options
author | Andrew White <andrew.white@unboxed.co> | 2016-10-31 17:21:15 +0000 |
---|---|---|
committer | Andrew White <andrew.white@unboxed.co> | 2016-10-31 17:25:43 +0000 |
commit | 8931916f4a1c1d8e70c06063ba63928c5c7eab1e (patch) | |
tree | 936a2edb3fcacb16cc7357309b682781d1ce4f9e /activerecord/lib/active_record/attribute_methods | |
parent | 3c9eb704e8b7fc175728f0340043b888120764cc (diff) | |
download | rails-8931916f4a1c1d8e70c06063ba63928c5c7eab1e.tar.gz rails-8931916f4a1c1d8e70c06063ba63928c5c7eab1e.tar.bz2 rails-8931916f4a1c1d8e70c06063ba63928c5c7eab1e.zip |
Ensure duration parsing is consistent across DST changes
Previously `ActiveSupport::Duration.parse` used `Time.current` and
`Time#advance` to calculate the number of seconds in the duration
from an arbitrary collection of parts. However as `advance` tries to
be consistent across DST boundaries this meant that either the
duration was shorter or longer depending on the time of year.
This was fixed by using an absolute reference point in UTC which
isn't subject to DST transitions. An arbitrary date of Jan 1st, 2000
was chosen for no other reason that it seemed appropriate.
Additionally, duration parsing should now be marginally faster as we
are no longer creating instances of `ActiveSupport::TimeWithZone`
every time we parse a duration string.
Fixes #26941.
Diffstat (limited to 'activerecord/lib/active_record/attribute_methods')
0 files changed, 0 insertions, 0 deletions