diff options
author | Xavier Noria <fxn@hashref.com> | 2011-12-30 02:13:37 -0800 |
---|---|---|
committer | Xavier Noria <fxn@hashref.com> | 2011-12-30 02:13:37 -0800 |
commit | edfe7d80135465858bda841b0bc5991f14f35295 (patch) | |
tree | 2bb3e0a36e47c64e278c8813cbeb2700a07136a5 | |
parent | e43b2b35c7042c87fd18e3ecd55c14eabd5746ba (diff) | |
parent | 952e9d9005b775827b17227e040499d0324bb928 (diff) | |
download | rails-edfe7d80135465858bda841b0bc5991f14f35295.tar.gz rails-edfe7d80135465858bda841b0bc5991f14f35295.tar.bz2 rails-edfe7d80135465858bda841b0bc5991f14f35295.zip |
Merge pull request #4229 from lest/range-include
refactor Range#include? to handle ranges with floats
-rw-r--r-- | activesupport/lib/active_support/core_ext/range/include_range.rb | 3 | ||||
-rw-r--r-- | activesupport/test/core_ext/range_ext_test.rb | 4 |
2 files changed, 6 insertions, 1 deletions
diff --git a/activesupport/lib/active_support/core_ext/range/include_range.rb b/activesupport/lib/active_support/core_ext/range/include_range.rb index c9986d4724..38a90490e6 100644 --- a/activesupport/lib/active_support/core_ext/range/include_range.rb +++ b/activesupport/lib/active_support/core_ext/range/include_range.rb @@ -9,7 +9,8 @@ class Range # (5..9).include?(11) # => false def include_with_range?(value) if value.is_a?(::Range) - min <= value.min && max >= value.max + operator = exclude_end? && !value.exclude_end? ? :< : :<= + include_without_range?(value.first) && value.last.send(operator, last) else include_without_range?(value) end diff --git a/activesupport/test/core_ext/range_ext_test.rb b/activesupport/test/core_ext/range_ext_test.rb index f4b773e5fb..7a620305f3 100644 --- a/activesupport/test/core_ext/range_ext_test.rb +++ b/activesupport/test/core_ext/range_ext_test.rb @@ -53,6 +53,10 @@ class RangeTest < Test::Unit::TestCase assert !(2..8).include?(5..9) end + def test_should_include_identical_exclusive_with_floats + assert (1.0...10.0).include?(1.0...10.0) + end + def test_blockless_step assert_equal [1,3,5,7,9], (1..10).step(2) end |