summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorJesus Cea <jcea@jcea.es>2012-08-03 12:52:12 (GMT)
committerJesus Cea <jcea@jcea.es>2012-08-03 12:52:12 (GMT)
commit1659b75189d366ed05e7e43d394513ee5c5dc790 (patch)
treefe90b20bc24bb4876a8e7cda2ac68373237b0ad5 /Lib
parent88ca04e6a8d1e5b31da69717e0e0cde2c069d7eb (diff)
parent16e2fca47e44e6244d7aaa285fde5ae162c4baab (diff)
downloadcpython-1659b75189d366ed05e7e43d394513ee5c5dc790.zip
cpython-1659b75189d366ed05e7e43d394513ee5c5dc790.tar.gz
cpython-1659b75189d366ed05e7e43d394513ee5c5dc790.tar.bz2
MERGE: Closes #15469: Correct __sizeof__ support for deque
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_deque.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/Lib/test/test_deque.py b/Lib/test/test_deque.py
index 24125cd..a8487d2 100644
--- a/Lib/test/test_deque.py
+++ b/Lib/test/test_deque.py
@@ -7,6 +7,7 @@ import copy
import pickle
from io import StringIO
import random
+import struct
BIG = 100000
@@ -531,6 +532,21 @@ class TestBasic(unittest.TestCase):
gc.collect()
self.assertTrue(ref() is None, "Cycle was not collected")
+ check_sizeof = support.check_sizeof
+
+ @support.cpython_only
+ def test_sizeof(self):
+ BLOCKLEN = 62
+ basesize = support.calcobjsize('2P4nlP')
+ blocksize = struct.calcsize('2P%dP' % BLOCKLEN)
+ self.assertEqual(object.__sizeof__(deque()), basesize)
+ check = self.check_sizeof
+ check(deque(), basesize + blocksize)
+ check(deque('a'), basesize + blocksize)
+ check(deque('a' * (BLOCKLEN // 2)), basesize + blocksize)
+ check(deque('a' * (BLOCKLEN // 2 + 1)), basesize + 2 * blocksize)
+ check(deque('a' * (42 * BLOCKLEN)), basesize + 43 * blocksize)
+
class TestVariousIteratorArgs(unittest.TestCase):
def test_constructor(self):