diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-04-17 02:41:00 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-04-17 02:41:00 +0000 |
commit | 61ea519dc08cffdad3d39ff48d281f60da81e858 (patch) | |
tree | a2618c43fd928fa8b0d64c9128fe2b75f2faa122 /test | |
parent | e601e775905f356f897857759c479d5ab76b2286 (diff) | |
download | ruby-61ea519dc08cffdad3d39ff48d281f60da81e858.tar.gz |
eval.c: copy before cause setup
* eval.c (setup_exception): copy frozen exception before setting
up a cause not only a backtrace.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@58381 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r-- | test/ruby/test_exception.rb | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/test/ruby/test_exception.rb b/test/ruby/test_exception.rb index 37b5f7068c..1179c26c51 100644 --- a/test/ruby/test_exception.rb +++ b/test/ruby/test_exception.rb @@ -799,6 +799,13 @@ end.join assert_nil(orig_error.cause, bug13043) end + def test_cause_with_frozen_exception + exc = ArgumentError.new("foo").freeze + assert_raise_with_message(ArgumentError, exc.message) { + raise exc, cause: RuntimeError.new("bar") + } + end + def test_anonymous_message assert_in_out_err([], "raise Class.new(RuntimeError), 'foo'", [], /foo\n/) end |