From 6cf6d8556c1df4962ae5775538690e4957e2ac1a Mon Sep 17 00:00:00 2001 From: tenderlove Date: Sun, 1 Nov 2009 01:46:44 +0000 Subject: * ext/dl/cptr.c (rb_dlptr_size) splitting function to reduce complexity * ext/dl/cptr.c (rb_dlptr_null_p, rb_dlptr_aref, rb_dlptr_aset) adding documentation * ext/dl/dl.c (rb_dl_free) adding documentation * test/dl/test_cptr.rb (test_null?, test_size, test_size=, test_aref_aset) Improving test coverage * test/dl/test_dl2.rb (test_free_secure) improving test coverage git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25606 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/dl/test_cptr.rb | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ test/dl/test_dl2.rb | 31 +++++++++---------------------- 2 files changed, 61 insertions(+), 22 deletions(-) (limited to 'test') diff --git a/test/dl/test_cptr.rb b/test/dl/test_cptr.rb index 55a53f97da..4157f83361 100644 --- a/test/dl/test_cptr.rb +++ b/test/dl/test_cptr.rb @@ -29,5 +29,57 @@ module DL assert_equal free.ptr, ptr.free.ptr end + + def test_null? + ptr = CPtr.new(0) + assert ptr.null? + end + + def test_size + ptr = CPtr.malloc(4) + assert_equal 4, ptr.size + DL.free ptr.to_i + end + + def test_size= + ptr = CPtr.malloc(4) + ptr.size = 10 + assert_equal 10, ptr.size + DL.free ptr.to_i + end + + def test_aref_aset + check = Proc.new{|str,ptr| + assert_equal(str.size(), ptr.size()) + assert_equal(str, ptr.to_s()) + assert_equal(str[0,2], ptr.to_s(2)) + assert_equal(str[0,2], ptr[0,2]) + assert_equal(str[1,2], ptr[1,2]) + assert_equal(str[1,0], ptr[1,0]) + assert_equal(str[0].ord, ptr[0]) + assert_equal(str[1].ord, ptr[1]) + } + str = 'abc' + ptr = CPtr[str] + check.call(str, ptr) + + str[0] = "c" + assert_equal 'c'.ord, ptr[0] = "c".ord + check.call(str, ptr) + + str[0,2] = "aa" + assert_equal 'aa', ptr[0,2] = "aa" + check.call(str, ptr) + + ptr2 = CPtr['cdeeee'] + str[0,2] = "cd" + assert_equal ptr2, ptr[0,2] = ptr2 + check.call(str, ptr) + + ptr3 = CPtr['vvvv'] + str[0,2] = "vv" + assert_equal ptr3.to_i, ptr[0,2] = ptr3.to_i + check.call(str, ptr) + end end end diff --git a/test/dl/test_dl2.rb b/test/dl/test_dl2.rb index d391e976e5..ac1414920f 100644 --- a/test/dl/test_dl2.rb +++ b/test/dl/test_dl2.rb @@ -5,6 +5,15 @@ module DL class TestDL < TestBase # TODO: refactor test repetition + def test_free_secure + assert_raises(SecurityError) do + Thread.new do + $SAFE = 4 + DL.free(0) + end.join + end + end + def test_realloc str = "abc" ptr_id = DL.realloc(0, 4) @@ -133,27 +142,5 @@ class TestDL < TestBase ary2 = dlunwrap(addr) assert_equal(ary, ary2) end - - def test_cptr() - check = Proc.new{|str,ptr| - assert_equal(str.size(), ptr.size()) - assert_equal(str, ptr.to_s()) - assert_equal(str[0,2], ptr.to_s(2)) - assert_equal(str[0,2], ptr[0,2]) - assert_equal(str[1,2], ptr[1,2]) - assert_equal(str[1,0], ptr[1,0]) - assert_equal(str[0].ord, ptr[0]) - assert_equal(str[1].ord, ptr[1]) - } - str = 'abc' - ptr = CPtr[str] - check.call(str, ptr) - str[0] = "c" - ptr[0] = "c".ord - check.call(str, ptr) - str[0,2] = "aa" - ptr[0,2] = "aa" - check.call(str, ptr) - end end end # module DL -- cgit v1.2.3