summaryrefslogtreecommitdiff
path: root/test/strscan
diff options
context:
space:
mode:
authorKenichi Kamiya <kachick1@gmail.com>2021-03-31 14:56:28 +0900
committerHiroshi SHIBATA <hsbt@ruby-lang.org>2021-05-06 16:20:38 +0900
commit564ccd095a9d7fbe869031dbf666d61dadfdcb03 (patch)
tree45cc3d8161e3f225281dd66dbba1e622661fc8c8 /test/strscan
parent822eb945635974ba904393cd130071d34e4bdc12 (diff)
downloadruby-564ccd095a9d7fbe869031dbf666d61dadfdcb03.tar.gz
[ruby/strscan] Fix segmentation fault of `StringScanner#charpos` when `String#byteslice` returns non string value [Bug #17756] (#20)
https://github.com/ruby/strscan/commit/92961cde2b
Diffstat (limited to 'test/strscan')
-rw-r--r--test/strscan/test_stringscanner.rb17
1 files changed, 17 insertions, 0 deletions
diff --git a/test/strscan/test_stringscanner.rb b/test/strscan/test_stringscanner.rb
index 4b001b317e..6e30be1f7d 100644
--- a/test/strscan/test_stringscanner.rb
+++ b/test/strscan/test_stringscanner.rb
@@ -206,6 +206,23 @@ class TestStringScanner < Test::Unit::TestCase
assert_equal 11, s.charpos
end
+ def test_charpos_not_use_string_methods
+ string = +'abcädeföghi'
+ scanner = create_string_scanner(string)
+
+ class << string
+ EnvUtil.suppress_warning do
+ undef_method(*instance_methods)
+ end
+ end
+
+ assert_equal 0, scanner.charpos
+ assert_equal "abcä", scanner.scan_until(/ä/)
+ assert_equal 4, scanner.charpos
+ assert_equal "defö", scanner.scan_until(/ö/)
+ assert_equal 8, scanner.charpos
+ end
+
def test_concat
s = create_string_scanner('a'.dup)
s.scan(/a/)