diff options
author | tenderlove <tenderlove@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-10-25 00:11:15 +0000 |
---|---|---|
committer | tenderlove <tenderlove@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-10-25 00:11:15 +0000 |
commit | 60f86b2edbabb25cdce5ae0898a50f8edfc8a143 (patch) | |
tree | 292697f25ece9d734bd890f607bb5d36e628e7dd /test/dl/test_handle.rb | |
parent | c30de1e38e8d5ff633ebe90e110c5acdaa79f583 (diff) | |
download | ruby-60f86b2edbabb25cdce5ae0898a50f8edfc8a143.tar.gz |
* ext/dl/handle.c (rb_dlhandle_sym) refactoring rb_secure(2)
* test/dl/test_handle.rb (**) testing sym behavior
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25460 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/dl/test_handle.rb')
-rw-r--r-- | test/dl/test_handle.rb | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/test/dl/test_handle.rb b/test/dl/test_handle.rb index 59582e96b2..ab9c1c13a3 100644 --- a/test/dl/test_handle.rb +++ b/test/dl/test_handle.rb @@ -2,6 +2,25 @@ require 'test_base' module DL class TestHandle < TestBase + def test_static_sym_secure + assert_raises(SecurityError) do + Thread.new do + $SAFE = 2 + DL::Handle.sym('calloc') + end.join + end + end + + def test_static_sym_unknown + assert_raises(DL::DLError) { DL::Handle.sym('fooo') } + assert_raises(DL::DLError) { DL::Handle['fooo'] } + end + + def test_static_sym + assert DL::Handle.sym('dlopen') + assert_equal DL::Handle.sym('dlopen'), DL::Handle['dlopen'] + end + def test_sym_closed_handle handle = DL::Handle.new(LIBC_SO) handle.close @@ -21,6 +40,16 @@ module DL assert_raises(TypeError) { handle[nil] } end + def test_sym_secure + assert_raises(SecurityError) do + Thread.new do + $SAFE = 2 + handle = DL::Handle.new(LIBC_SO) + handle.sym('calloc') + end.join + end + end + def test_sym handle = DL::Handle.new(LIBC_SO) assert handle.sym('calloc') |