From 24df9a76903702303b2fb6122bbd8e7322a4e7fa Mon Sep 17 00:00:00 2001 From: nagachika Date: Sun, 2 Mar 2014 16:10:47 +0000 Subject: merge revision(s) r45187,r45205,r45212,r45213: [Backport #9570] * numeric.c (ruby_num_interval_step_size): check signs and get rid of implementation dependent behavior of negative division. [ruby-core:61106] [Bug #9570] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@45250 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/ruby/test_numeric.rb | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) (limited to 'test') diff --git a/test/ruby/test_numeric.rb b/test/ruby/test_numeric.rb index b99ce988a1..66f11ab801 100644 --- a/test/ruby/test_numeric.rb +++ b/test/ruby/test_numeric.rb @@ -243,17 +243,32 @@ class TestNumeric < Test::Unit::TestCase end def test_step + i, bignum = 32, 1 << 30 + bignum <<= (i <<= 1) - 32 until bignum.is_a?(Bignum) assert_raise(ArgumentError) { 1.step(10, 1, 0) { } } assert_raise(ArgumentError) { 1.step(10, 0) { } } + assert_equal(bignum*2+1, (-bignum).step(bignum, 1).size) + assert_equal(bignum*2, (-bignum).step(bignum-1, 1).size) + + assert_equal(10+1, (0.0).step(10.0, 1.0).size) + + i, bigflo = 1, bignum.to_f + i <<= 1 until (bigflo - i).to_i < bignum + bigflo -= i >> 1 + assert_equal(bigflo.to_i, (0.0).step(bigflo-1.0, 1.0).size) + assert_operator((0.0).step(bignum.to_f, 1.0).size, :>=, bignum) # may loose precision + assert_step [1, 2, 3, 4, 5, 6, 7, 8, 9, 10], [1, 10] assert_step [1, 3, 5, 7, 9], [1, 10, 2] assert_step [10, 8, 6, 4, 2], [10, 1, -2] assert_step [1.0, 3.0, 5.0, 7.0, 9.0], [1.0, 10.0, 2.0] - assert_step [1], [1, 10, 2**32] + assert_step [1], [1, 10, bignum] - assert_step [10], [10, 1, -(2**32)] + assert_step [], [2, 1, 3] + assert_step [], [-2, -1, -3] + assert_step [10], [10, 1, -(bignum)] assert_step [], [1, 0, Float::INFINITY] assert_step [], [0, 1, -Float::INFINITY] -- cgit v1.2.3