diff options
author | Sayan Chakraborty <mail.sayanc@gmail.com> | 2017-07-01 19:18:18 +0530 |
---|---|---|
committer | Sayan Chakraborty <mail.sayanc@gmail.com> | 2017-12-17 23:56:16 +0530 |
commit | eb73dfc0677cb5b3a0f559020fe5d7df556056b4 (patch) | |
tree | f3973a4e3105381205e669228f12ef46476e3b3f /activemodel/test/cases | |
parent | de354cc3573e8b6e81448080a21c313f5bdbab7b (diff) | |
download | rails-eb73dfc0677cb5b3a0f559020fe5d7df556056b4.tar.gz rails-eb73dfc0677cb5b3a0f559020fe5d7df556056b4.tar.bz2 rails-eb73dfc0677cb5b3a0f559020fe5d7df556056b4.zip |
Return correct date in ActiveModel for time to date conversions
time.to_date conversion happens considering leap years
so a conversion of "Day.new({'day(1i)'=>'1', 'day(2i)'=>'1', 'day(3i)'=>'1'})" results in saving the date as Mon, 03 Jan 0001
which might seem weird on the user level, hence falling back to parsing on string level resolves this data mismatch
Fixes #28521
Diffstat (limited to 'activemodel/test/cases')
-rw-r--r-- | activemodel/test/cases/type/date_test.rb | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/activemodel/test/cases/type/date_test.rb b/activemodel/test/cases/type/date_test.rb index e8cf178612..c50a549d3d 100644 --- a/activemodel/test/cases/type/date_test.rb +++ b/activemodel/test/cases/type/date_test.rb @@ -15,6 +15,17 @@ module ActiveModel date_string = ::Time.now.utc.strftime("%F") assert_equal date_string, type.cast(date_string).strftime("%F") end + + def test_returns_correct_year + type = Type::Date.new + + time = ::Time.utc(1, 1, 1) + date = ::Date.new(time.year, time.mon, time.mday) + + values_hash_for_multiparameter_assignment = { 1 => 1, 2 => 1, 3 => 1 } + + assert_equal date, type.cast(values_hash_for_multiparameter_assignment) + end end end end |