diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-07-15 08:29:03 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-07-15 08:29:03 +0000 |
commit | 1b27045a1514218140f0cecb0e928f2f2a9a4194 (patch) | |
tree | c1673a07e0d1ae963a963b77e221ca4724e00433 /test/ruby/test_parse.rb | |
parent | 781170cafa37e5e4b180f6d21a9a741c729e8c4b (diff) | |
download | ruby-1b27045a1514218140f0cecb0e928f2f2a9a4194.tar.gz |
parse.y: refine error messages
* parse.y (parser_read_escape, parser_tok_hex): refine error
messages. point from the backslash up to the invalid char.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59341 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_parse.rb')
-rw-r--r-- | test/ruby/test_parse.rb | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/test/ruby/test_parse.rb b/test/ruby/test_parse.rb index d6850f4bfd..46d9470287 100644 --- a/test/ruby/test_parse.rb +++ b/test/ruby/test_parse.rb @@ -484,21 +484,27 @@ class TestParse < Test::Unit::TestCase end def test_string - assert_raise(SyntaxError) do + mesg = 'from the backslash through the invalid char' + + e = assert_raise_with_message(SyntaxError, /hex escape/) do eval '"\xg1"' end + assert_equal(' ^', e.message.lines.last, mesg) - assert_raise(SyntaxError) do + e = assert_raise(SyntaxError) do eval '"\u{1234"' end + assert_match(' ^~~~~~~', e.message.lines.last, mesg) - assert_raise(SyntaxError) do + e = assert_raise_with_message(SyntaxError, /escape character syntax/) do eval '"\M1"' end + assert_equal(' ^~~', e.message.lines.last, mesg) - assert_raise(SyntaxError) do + e = assert_raise_with_message(SyntaxError, /escape character syntax/) do eval '"\C1"' end + assert_equal(' ^~~', e.message.lines.last, mesg) assert_equal("\x81", eval('"\C-\M-a"')) assert_equal("\177", eval('"\c?"')) |