From 2743b0d6082561a55c6a0d0843201f2413de93f3 Mon Sep 17 00:00:00 2001 From: nobu Date: Tue, 6 Aug 2013 08:42:51 +0000 Subject: range.c: consider exclusive * range.c (range_last): exclude the last number of the exclusive range if the end is Numeric. [ruby-dev:47587] [Bug #8739] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42400 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/ruby/test_range.rb | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'test/ruby/test_range.rb') diff --git a/test/ruby/test_range.rb b/test/ruby/test_range.rb index e12e8fc438..c50139ef9c 100644 --- a/test/ruby/test_range.rb +++ b/test/ruby/test_range.rb @@ -250,6 +250,18 @@ class TestRange < Test::Unit::TestCase def test_first_last assert_equal([0, 1, 2], (0..10).first(3)) assert_equal([8, 9, 10], (0..10).last(3)) + assert_equal(0, (0..10).first) + assert_equal(10, (0..10).last) + assert_equal("a", ("a".."c").first) + assert_equal("c", ("a".."c").last) + + bug8739 = '[ruby-dev:47587] [Bug #8739] from exclusive range' + assert_equal([0, 1, 2], (0...10).first(3), bug8739) + assert_equal([7, 8, 9], (0...10).last(3), bug8739) + assert_equal(0, (0...10).first, bug8739) + assert_equal(9, (0...10).last, bug8739) + assert_equal("a", ("a"..."c").first, bug8739) + assert_equal("b", ("a"..."c").last, bug8739) end def test_to_s -- cgit v1.2.3