diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-02-10 07:31:06 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-02-10 07:31:06 +0000 |
commit | f3f43cdbee1703afd92f9f6dbb471642bcede9f5 (patch) | |
tree | 4f97958bcbb0220be3dd81af4fff045127369f76 /test/ruby/test_string.rb | |
parent | 6942afef5f8eb829b85b05bbea59c9eb9214739c (diff) | |
download | ruby-f3f43cdbee1703afd92f9f6dbb471642bcede9f5.tar.gz |
* array.c (rb_ary_push_m, rb_ary_unshift_m, rb_ary_aset),
(rb_ary_insert, rb_ary_replace, rb_ary_concat),
(rb_ary_uniq_bang, rb_ary_flatten_bang): check if frozen after
wrong number of arguments but before TypeError.
[ruby-core:28140]
* hash.c (rb_hash_replace): ditto.
* string.c (rb_str_replace): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26632 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_string.rb')
-rw-r--r-- | test/ruby/test_string.rb | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/test/ruby/test_string.rb b/test/ruby/test_string.rb index 5d8edc1684..64205f6082 100644 --- a/test/ruby/test_string.rb +++ b/test/ruby/test_string.rb @@ -875,6 +875,12 @@ class TestString < Test::Unit::TestCase s2 = ["foo"].pack("p") s.replace(s2) assert_equal(s2, s) + + fs = "".freeze + assert_raise(RuntimeError) { fs.replace("a") } + assert_raise(RuntimeError) { fs.replace(fs) } + assert_raise(ArgumentError) { fs.replace() } + assert_raise(RuntimeError) { fs.replace(42) } end def test_reverse |