diff options
author | marcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-10-23 15:13:19 +0000 |
---|---|---|
committer | marcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-10-23 15:13:19 +0000 |
commit | b9e18abe4a881a638d0c6cfbbffeacea43813e86 (patch) | |
tree | f63472b042e0adcae44d8b3e7e995eeade114541 | |
parent | dc215dcd9f96620b7c06a25a741d13b19c2f130b (diff) |
* lib/ostruct.rb: Raise RuntimeError when modifying frozen instances
instead of TypeError. Patch by Kenichi Kamiya. [Fixes GH-383]
* test/ostruct/test_ostruct.rb: Added tests for above.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43402 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | lib/ostruct.rb | 2 | ||||
-rw-r--r-- | test/ostruct/test_ostruct.rb | 6 |
2 files changed, 4 insertions, 4 deletions
diff --git a/lib/ostruct.rb b/lib/ostruct.rb index df09cc953f..6b60bdf3fe 100644 --- a/lib/ostruct.rb +++ b/lib/ostruct.rb @@ -152,7 +152,7 @@ class OpenStruct begin @modifiable = true rescue - raise TypeError, "can't modify frozen #{self.class}", caller(3) + raise RuntimeError, "can't modify frozen #{self.class}", caller(3) end @table end diff --git a/test/ostruct/test_ostruct.rb b/test/ostruct/test_ostruct.rb index d82bab9784..a472509b88 100644 --- a/test/ostruct/test_ostruct.rb +++ b/test/ostruct/test_ostruct.rb @@ -46,14 +46,14 @@ class TC_OpenStruct < Test::Unit::TestCase o = OpenStruct.new o.a = 'a' o.freeze - assert_raise(TypeError) {o.b = 'b'} + assert_raise(RuntimeError) {o.b = 'b'} assert_not_respond_to(o, :b) - assert_raise(TypeError) {o.a = 'z'} + assert_raise(RuntimeError) {o.a = 'z'} assert_equal('a', o.a) o = OpenStruct.new :a => 42 def o.frozen?; nil end o.freeze - assert_raise(TypeError, '[ruby-core:22559]') {o.a = 1764} + assert_raise(RuntimeError, '[ruby-core:22559]') {o.a = 1764} end def test_delete_field |