From a022789ab38c65cae5302f363f1cec92f807e859 Mon Sep 17 00:00:00 2001 From: Thomas Heller Date: Mon, 13 Mar 2006 10:47:02 +0000 Subject: Plug some refcount leaks when tests are run repeatedly. --- Lib/ctypes/test/test_checkretval.py | 12 ++++++------ Lib/ctypes/test/test_repr.py | 25 +++++++++++++++---------- 2 files changed, 21 insertions(+), 16 deletions(-) diff --git a/Lib/ctypes/test/test_checkretval.py b/Lib/ctypes/test/test_checkretval.py index 7a9cd22..344d0bc 100644 --- a/Lib/ctypes/test/test_checkretval.py +++ b/Lib/ctypes/test/test_checkretval.py @@ -3,16 +3,16 @@ import sys from ctypes import * +class CHECKED(c_int): + def _check_retval_(value): + # Receives a CHECKED instance. + return str(value.value) + _check_retval_ = staticmethod(_check_retval_) + class Test(unittest.TestCase): def test_checkretval(self): - class CHECKED(c_int): - def _check_retval_(value): - # Receives a CHECKED instance. - return str(value.value) - _check_retval_ = staticmethod(_check_retval_) - import _ctypes_test dll = cdll.load(_ctypes_test.__file__) self.failUnlessEqual(42, dll._testfunc_p_p(42)) diff --git a/Lib/ctypes/test/test_repr.py b/Lib/ctypes/test/test_repr.py index 450b82f..1044f67 100644 --- a/Lib/ctypes/test/test_repr.py +++ b/Lib/ctypes/test/test_repr.py @@ -1,23 +1,28 @@ from ctypes import * import unittest -nums = [c_byte, c_short, c_int, c_long, c_longlong, +subclasses = [] +for base in [c_byte, c_short, c_int, c_long, c_longlong, c_ubyte, c_ushort, c_uint, c_ulong, c_ulonglong, - c_float, c_double] + c_float, c_double]: + class X(base): + pass + subclasses.append(X) + +class X(c_char): + pass + +# This test checks if the __repr__ is correct for subclasses of simple types class ReprTest(unittest.TestCase): def test_numbers(self): - for typ in nums: - self.failUnless(repr(typ(42)).startswith(typ.__name__)) - class X(typ): - pass - self.failUnlessEqual("