mirror of
https://github.com/python/cpython.git
synced 2025-08-03 16:39:00 +00:00

number of tests, all because of the codecs/_multibytecodecs issue described here (it's not a Py3K issue, just something Py3K discovers): http://mail.python.org/pipermail/python-dev/2006-April/064051.html Hye-Shik Chang promised to look for a fix, so no need to fix it here. The tests that are expected to break are: test_codecencodings_cn test_codecencodings_hk test_codecencodings_jp test_codecencodings_kr test_codecencodings_tw test_codecs test_multibytecodec This merge fixes an actual test failure (test_weakref) in this branch, though, so I believe merging is the right thing to do anyway.
503 lines
9.5 KiB
Python
503 lines
9.5 KiB
Python
from pybench import Test
|
|
|
|
class DictCreation(Test):
|
|
|
|
version = 0.3
|
|
operations = 5*(5 + 5)
|
|
rounds = 60000
|
|
|
|
def test(self):
|
|
|
|
for i in xrange(self.rounds):
|
|
|
|
d1 = {}
|
|
d2 = {}
|
|
d3 = {}
|
|
d4 = {}
|
|
d5 = {}
|
|
|
|
d1 = {1:2,3:4,5:6}
|
|
d2 = {2:3,4:5,6:7}
|
|
d3 = {3:4,5:6,7:8}
|
|
d4 = {4:5,6:7,8:9}
|
|
d5 = {6:7,8:9,10:11}
|
|
|
|
d1 = {}
|
|
d2 = {}
|
|
d3 = {}
|
|
d4 = {}
|
|
d5 = {}
|
|
|
|
d1 = {1:2,3:4,5:6}
|
|
d2 = {2:3,4:5,6:7}
|
|
d3 = {3:4,5:6,7:8}
|
|
d4 = {4:5,6:7,8:9}
|
|
d5 = {6:7,8:9,10:11}
|
|
|
|
d1 = {}
|
|
d2 = {}
|
|
d3 = {}
|
|
d4 = {}
|
|
d5 = {}
|
|
|
|
d1 = {1:2,3:4,5:6}
|
|
d2 = {2:3,4:5,6:7}
|
|
d3 = {3:4,5:6,7:8}
|
|
d4 = {4:5,6:7,8:9}
|
|
d5 = {6:7,8:9,10:11}
|
|
|
|
d1 = {}
|
|
d2 = {}
|
|
d3 = {}
|
|
d4 = {}
|
|
d5 = {}
|
|
|
|
d1 = {1:2,3:4,5:6}
|
|
d2 = {2:3,4:5,6:7}
|
|
d3 = {3:4,5:6,7:8}
|
|
d4 = {4:5,6:7,8:9}
|
|
d5 = {6:7,8:9,10:11}
|
|
|
|
d1 = {}
|
|
d2 = {}
|
|
d3 = {}
|
|
d4 = {}
|
|
d5 = {}
|
|
|
|
d1 = {1:2,3:4,5:6}
|
|
d2 = {2:3,4:5,6:7}
|
|
d3 = {3:4,5:6,7:8}
|
|
d4 = {4:5,6:7,8:9}
|
|
d5 = {6:7,8:9,10:11}
|
|
|
|
def calibrate(self):
|
|
|
|
for i in xrange(self.rounds):
|
|
pass
|
|
|
|
class DictWithStringKeys(Test):
|
|
|
|
version = 0.1
|
|
operations = 5*(6 + 6)
|
|
rounds = 200000
|
|
|
|
def test(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
|
|
d['abc'] = 1
|
|
d['def'] = 2
|
|
d['ghi'] = 3
|
|
d['jkl'] = 4
|
|
d['mno'] = 5
|
|
d['pqr'] = 6
|
|
|
|
d['abc']
|
|
d['def']
|
|
d['ghi']
|
|
d['jkl']
|
|
d['mno']
|
|
d['pqr']
|
|
|
|
d['abc'] = 1
|
|
d['def'] = 2
|
|
d['ghi'] = 3
|
|
d['jkl'] = 4
|
|
d['mno'] = 5
|
|
d['pqr'] = 6
|
|
|
|
d['abc']
|
|
d['def']
|
|
d['ghi']
|
|
d['jkl']
|
|
d['mno']
|
|
d['pqr']
|
|
|
|
d['abc'] = 1
|
|
d['def'] = 2
|
|
d['ghi'] = 3
|
|
d['jkl'] = 4
|
|
d['mno'] = 5
|
|
d['pqr'] = 6
|
|
|
|
d['abc']
|
|
d['def']
|
|
d['ghi']
|
|
d['jkl']
|
|
d['mno']
|
|
d['pqr']
|
|
|
|
d['abc'] = 1
|
|
d['def'] = 2
|
|
d['ghi'] = 3
|
|
d['jkl'] = 4
|
|
d['mno'] = 5
|
|
d['pqr'] = 6
|
|
|
|
d['abc']
|
|
d['def']
|
|
d['ghi']
|
|
d['jkl']
|
|
d['mno']
|
|
d['pqr']
|
|
|
|
d['abc'] = 1
|
|
d['def'] = 2
|
|
d['ghi'] = 3
|
|
d['jkl'] = 4
|
|
d['mno'] = 5
|
|
d['pqr'] = 6
|
|
|
|
d['abc']
|
|
d['def']
|
|
d['ghi']
|
|
d['jkl']
|
|
d['mno']
|
|
d['pqr']
|
|
|
|
def calibrate(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
pass
|
|
|
|
class DictWithFloatKeys(Test):
|
|
|
|
version = 0.1
|
|
operations = 5*(6 + 6)
|
|
rounds = 200000
|
|
|
|
def test(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
|
|
d[1.234] = 1
|
|
d[2.345] = 2
|
|
d[3.456] = 3
|
|
d[4.567] = 4
|
|
d[5.678] = 5
|
|
d[6.789] = 6
|
|
|
|
d[1.234]
|
|
d[2.345]
|
|
d[3.456]
|
|
d[4.567]
|
|
d[5.678]
|
|
d[6.789]
|
|
|
|
d[1.234] = 1
|
|
d[2.345] = 2
|
|
d[3.456] = 3
|
|
d[4.567] = 4
|
|
d[5.678] = 5
|
|
d[6.789] = 6
|
|
|
|
d[1.234]
|
|
d[2.345]
|
|
d[3.456]
|
|
d[4.567]
|
|
d[5.678]
|
|
d[6.789]
|
|
|
|
d[1.234] = 1
|
|
d[2.345] = 2
|
|
d[3.456] = 3
|
|
d[4.567] = 4
|
|
d[5.678] = 5
|
|
d[6.789] = 6
|
|
|
|
d[1.234]
|
|
d[2.345]
|
|
d[3.456]
|
|
d[4.567]
|
|
d[5.678]
|
|
d[6.789]
|
|
|
|
d[1.234] = 1
|
|
d[2.345] = 2
|
|
d[3.456] = 3
|
|
d[4.567] = 4
|
|
d[5.678] = 5
|
|
d[6.789] = 6
|
|
|
|
d[1.234]
|
|
d[2.345]
|
|
d[3.456]
|
|
d[4.567]
|
|
d[5.678]
|
|
d[6.789]
|
|
|
|
d[1.234] = 1
|
|
d[2.345] = 2
|
|
d[3.456] = 3
|
|
d[4.567] = 4
|
|
d[5.678] = 5
|
|
d[6.789] = 6
|
|
|
|
d[1.234]
|
|
d[2.345]
|
|
d[3.456]
|
|
d[4.567]
|
|
d[5.678]
|
|
d[6.789]
|
|
|
|
def calibrate(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
pass
|
|
|
|
class DictWithIntegerKeys(Test):
|
|
|
|
version = 0.1
|
|
operations = 5*(6 + 6)
|
|
rounds = 200000
|
|
|
|
def test(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
|
|
d[1] = 1
|
|
d[2] = 2
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
d[6] = 6
|
|
|
|
d[1]
|
|
d[2]
|
|
d[3]
|
|
d[4]
|
|
d[5]
|
|
d[6]
|
|
|
|
d[1] = 1
|
|
d[2] = 2
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
d[6] = 6
|
|
|
|
d[1]
|
|
d[2]
|
|
d[3]
|
|
d[4]
|
|
d[5]
|
|
d[6]
|
|
|
|
d[1] = 1
|
|
d[2] = 2
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
d[6] = 6
|
|
|
|
d[1]
|
|
d[2]
|
|
d[3]
|
|
d[4]
|
|
d[5]
|
|
d[6]
|
|
|
|
d[1] = 1
|
|
d[2] = 2
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
d[6] = 6
|
|
|
|
d[1]
|
|
d[2]
|
|
d[3]
|
|
d[4]
|
|
d[5]
|
|
d[6]
|
|
|
|
d[1] = 1
|
|
d[2] = 2
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
d[6] = 6
|
|
|
|
d[1]
|
|
d[2]
|
|
d[3]
|
|
d[4]
|
|
d[5]
|
|
d[6]
|
|
|
|
def calibrate(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
pass
|
|
|
|
class SimpleDictManipulation(Test):
|
|
|
|
version = 0.3
|
|
operations = 5*(6 + 6 + 6 + 6)
|
|
rounds = 50000
|
|
|
|
def test(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
|
|
d[0] = 3
|
|
d[1] = 4
|
|
d[2] = 5
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
|
|
x = d[0]
|
|
x = d[1]
|
|
x = d[2]
|
|
x = d[3]
|
|
x = d[4]
|
|
x = d[5]
|
|
|
|
d.has_key(0)
|
|
d.has_key(2)
|
|
d.has_key(4)
|
|
d.has_key(6)
|
|
d.has_key(8)
|
|
d.has_key(10)
|
|
|
|
del d[0]
|
|
del d[1]
|
|
del d[2]
|
|
del d[3]
|
|
del d[4]
|
|
del d[5]
|
|
|
|
d[0] = 3
|
|
d[1] = 4
|
|
d[2] = 5
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
|
|
x = d[0]
|
|
x = d[1]
|
|
x = d[2]
|
|
x = d[3]
|
|
x = d[4]
|
|
x = d[5]
|
|
|
|
d.has_key(0)
|
|
d.has_key(2)
|
|
d.has_key(4)
|
|
d.has_key(6)
|
|
d.has_key(8)
|
|
d.has_key(10)
|
|
|
|
del d[0]
|
|
del d[1]
|
|
del d[2]
|
|
del d[3]
|
|
del d[4]
|
|
del d[5]
|
|
|
|
d[0] = 3
|
|
d[1] = 4
|
|
d[2] = 5
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
|
|
x = d[0]
|
|
x = d[1]
|
|
x = d[2]
|
|
x = d[3]
|
|
x = d[4]
|
|
x = d[5]
|
|
|
|
d.has_key(0)
|
|
d.has_key(2)
|
|
d.has_key(4)
|
|
d.has_key(6)
|
|
d.has_key(8)
|
|
d.has_key(10)
|
|
|
|
del d[0]
|
|
del d[1]
|
|
del d[2]
|
|
del d[3]
|
|
del d[4]
|
|
del d[5]
|
|
|
|
d[0] = 3
|
|
d[1] = 4
|
|
d[2] = 5
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
|
|
x = d[0]
|
|
x = d[1]
|
|
x = d[2]
|
|
x = d[3]
|
|
x = d[4]
|
|
x = d[5]
|
|
|
|
d.has_key(0)
|
|
d.has_key(2)
|
|
d.has_key(4)
|
|
d.has_key(6)
|
|
d.has_key(8)
|
|
d.has_key(10)
|
|
|
|
del d[0]
|
|
del d[1]
|
|
del d[2]
|
|
del d[3]
|
|
del d[4]
|
|
del d[5]
|
|
|
|
d[0] = 3
|
|
d[1] = 4
|
|
d[2] = 5
|
|
d[3] = 3
|
|
d[4] = 4
|
|
d[5] = 5
|
|
|
|
x = d[0]
|
|
x = d[1]
|
|
x = d[2]
|
|
x = d[3]
|
|
x = d[4]
|
|
x = d[5]
|
|
|
|
d.has_key(0)
|
|
d.has_key(2)
|
|
d.has_key(4)
|
|
d.has_key(6)
|
|
d.has_key(8)
|
|
d.has_key(10)
|
|
|
|
del d[0]
|
|
del d[1]
|
|
del d[2]
|
|
del d[3]
|
|
del d[4]
|
|
del d[5]
|
|
|
|
def calibrate(self):
|
|
|
|
d = {}
|
|
|
|
for i in xrange(self.rounds):
|
|
pass
|
|
|