aboutsummaryrefslogtreecommitdiffstats
path: root/test/strscan
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-05-24 07:32:45 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-05-24 07:32:45 +0000
commitc43dd625b672589778ab6f2fe9c3e665c4199245 (patch)
tree330d8ebb77708a9211bef12a952b91afa42fc745 /test/strscan
parent755f669316b5d1ea5c618754e7c432ac1baf5b0e (diff)
downloadruby-c43dd625b672589778ab6f2fe9c3e665c4199245.tar.gz
* ext/strscan/strscan.c (strscan_aref): raise error if given
name reference is not found. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@40912 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/strscan')
-rw-r--r--test/strscan/test_stringscanner.rb11
1 files changed, 7 insertions, 4 deletions
diff --git a/test/strscan/test_stringscanner.rb b/test/strscan/test_stringscanner.rb
index 7f2e5c1ccd..be548d1938 100644
--- a/test/strscan/test_stringscanner.rb
+++ b/test/strscan/test_stringscanner.rb
@@ -402,6 +402,8 @@ class TestStringScanner < Test::Unit::TestCase
assert_equal 'stra', s[-1]
assert_equal 'stra', s[0]
assert_nil s[1]
+ assert_raise(IndexError) { s[:c] }
+ assert_raise(IndexError) { s['c'] }
assert_equal false, s[-1].tainted?
assert_equal false, s[0].tainted?
@@ -458,16 +460,17 @@ class TestStringScanner < Test::Unit::TestCase
assert_equal true, s[3].tainted?
assert_equal true, s[4].tainted?
- s = StringScanner.new("foo bar")
- s.scan /(?<a>(\w+)) (?<b>(\w+))/
+ s = StringScanner.new("foo bar baz")
+ s.scan /(?<a>\w+) (?<b>\w+) (\w+)/
assert_equal 'foo', s[1]
assert_equal 'bar', s[2]
+ assert_nil s[3]
assert_equal 'foo', s[:a]
assert_equal 'bar', s[:b]
- assert_equal nil, s[:c]
+ assert_raise(IndexError) { s[:c] }
assert_equal 'foo', s['a']
assert_equal 'bar', s['b']
- assert_equal nil, s['c']
+ assert_raise(IndexError) { s['c'] }
end
def test_pre_match