From 5777fe5ab57d6479326bdb21ef9a6b88ea1516dc Mon Sep 17 00:00:00 2001 From: nagachika Date: Fri, 18 Oct 2024 11:30:05 +0900 Subject: merge revision(s) 637067440f74043c6d79fc649ab8acf1afea25a5: [Backport #20752] [Bug #20752] Slice of readonly `IO::Buffer` also should be readonly --- test/ruby/test_io_buffer.rb | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'test/ruby/test_io_buffer.rb') diff --git a/test/ruby/test_io_buffer.rb b/test/ruby/test_io_buffer.rb index ae3fba2e41..f3eb37a513 100644 --- a/test/ruby/test_io_buffer.rb +++ b/test/ruby/test_io_buffer.rb @@ -209,6 +209,18 @@ class TestIOBuffer < Test::Unit::TestCase end end + def test_slice_readonly + hello = %w"Hello World".join(" ").freeze + buffer = IO::Buffer.for(hello) + slice = buffer.slice + assert_predicate slice, :readonly? + assert_raise IO::Buffer::AccessError do + # This breaks the literal in string pool and many other tests in this file. + slice.set_string("Adios", 0, 5) + end + assert_equal "Hello World", hello + end + def test_locked buffer = IO::Buffer.new(128, IO::Buffer::INTERNAL|IO::Buffer::LOCKED) -- cgit v1.2.3