merge 3.4
This commit is contained in:
commit
d7483993fe
|
@ -4974,11 +4974,33 @@ class PicklingTests(unittest.TestCase):
|
|||
self._assert_is_copy(obj, objcopy2)
|
||||
|
||||
|
||||
class SharedKeyTests(unittest.TestCase):
|
||||
|
||||
@support.cpython_only
|
||||
def test_subclasses(self):
|
||||
# Verify that subclasses can share keys (per PEP 412)
|
||||
class A:
|
||||
pass
|
||||
class B(A):
|
||||
pass
|
||||
|
||||
a, b = A(), B()
|
||||
self.assertEqual(sys.getsizeof(vars(a)), sys.getsizeof(vars(b)))
|
||||
self.assertLess(sys.getsizeof(vars(a)), sys.getsizeof({}))
|
||||
a.x, a.y, a.z, a.w = range(4)
|
||||
self.assertNotEqual(sys.getsizeof(vars(a)), sys.getsizeof(vars(b)))
|
||||
a2 = A()
|
||||
self.assertEqual(sys.getsizeof(vars(a)), sys.getsizeof(vars(a2)))
|
||||
self.assertLess(sys.getsizeof(vars(a)), sys.getsizeof({}))
|
||||
b.u, b.v, b.w, b.t = range(4)
|
||||
self.assertLess(sys.getsizeof(vars(b)), sys.getsizeof({}))
|
||||
|
||||
|
||||
def test_main():
|
||||
# Run all local test cases, with PTypesLongInitTest first.
|
||||
support.run_unittest(PTypesLongInitTest, OperatorsTest,
|
||||
ClassPropertiesAndMethods, DictProxyTests,
|
||||
MiscTests, PicklingTests)
|
||||
MiscTests, PicklingTests, SharedKeyTests)
|
||||
|
||||
if __name__ == "__main__":
|
||||
test_main()
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
# Python test set -- part 6, built-in types
|
||||
|
||||
from test.support import run_unittest, run_with_locale, cpython_only
|
||||
from test.support import run_unittest, run_with_locale
|
||||
import collections
|
||||
import pickle
|
||||
import locale
|
||||
|
@ -1170,31 +1170,9 @@ class SimpleNamespaceTests(unittest.TestCase):
|
|||
self.assertEqual(ns, ns_roundtrip, pname)
|
||||
|
||||
|
||||
class SharedKeyTests(unittest.TestCase):
|
||||
|
||||
@cpython_only
|
||||
def test_subclasses(self):
|
||||
# Verify that subclasses can share keys (per PEP 412)
|
||||
class A:
|
||||
pass
|
||||
class B(A):
|
||||
pass
|
||||
|
||||
a, b = A(), B()
|
||||
self.assertEqual(sys.getsizeof(vars(a)), sys.getsizeof(vars(b)))
|
||||
self.assertLess(sys.getsizeof(vars(a)), sys.getsizeof({}))
|
||||
a.x, a.y, a.z, a.w = range(4)
|
||||
self.assertNotEqual(sys.getsizeof(vars(a)), sys.getsizeof(vars(b)))
|
||||
a2 = A()
|
||||
self.assertEqual(sys.getsizeof(vars(a)), sys.getsizeof(vars(a2)))
|
||||
self.assertLess(sys.getsizeof(vars(a)), sys.getsizeof({}))
|
||||
b.u, b.v, b.w, b.t = range(4)
|
||||
self.assertLess(sys.getsizeof(vars(b)), sys.getsizeof({}))
|
||||
|
||||
|
||||
def test_main():
|
||||
run_unittest(TypesTests, MappingProxyTests, ClassCreationTests,
|
||||
SimpleNamespaceTests, SharedKeyTests)
|
||||
SimpleNamespaceTests)
|
||||
|
||||
if __name__ == '__main__':
|
||||
test_main()
|
||||
|
|
Loading…
Reference in New Issue