summaryrefslogtreecommitdiffstats
path: root/Lib/bsddb/test/test_dbshelve.py
diff options
context:
space:
mode:
Diffstat (limited to 'Lib/bsddb/test/test_dbshelve.py')
-rw-r--r--Lib/bsddb/test/test_dbshelve.py81
1 files changed, 37 insertions, 44 deletions
diff --git a/Lib/bsddb/test/test_dbshelve.py b/Lib/bsddb/test/test_dbshelve.py
index e75e9c8..f773156 100644
--- a/Lib/bsddb/test/test_dbshelve.py
+++ b/Lib/bsddb/test/test_dbshelve.py
@@ -8,12 +8,7 @@ from pprint import pprint
from types import *
import unittest
-try:
- # For Pythons w/distutils pybsddb
- from bsddb3 import db, dbshelve
-except ImportError:
- # For Python 2.3
- from bsddb import db, dbshelve
+from bsddb import db, dbshelve
from .test_all import verbose
@@ -56,15 +51,15 @@ class DBShelveTestCase(unittest.TestCase):
def populateDB(self, d):
for x in string.letters:
- d['S' + x] = 10 * x # add a string
- d['I' + x] = ord(x) # add an integer
- d['L' + x] = [x] * 10 # add a list
+ d[('S' + x).encode("ascii")] = 10 * x # add a string
+ d[('I' + x).encode("ascii")] = ord(x) # add an integer
+ d[('L' + x).encode("ascii")] = [x] * 10 # add a list
inst = DataClass() # add an instance
inst.S = 10 * x
inst.I = ord(x)
inst.L = [x] * 10
- d['O' + x] = inst
+ d[('O' + x).encode("ascii")] = inst
# overridable in derived classes to affect how the shelf is created/opened
@@ -98,14 +93,14 @@ class DBShelveTestCase(unittest.TestCase):
print("keys:", k)
print("stats:", s)
- assert 0 == d.has_key('bad key')
- assert 1 == d.has_key('IA')
- assert 1 == d.has_key('OA')
+ assert 0 == d.has_key(b'bad key')
+ assert 1 == d.has_key(b'IA')
+ assert 1 == d.has_key(b'OA')
- d.delete('IA')
- del d['OA']
- assert 0 == d.has_key('IA')
- assert 0 == d.has_key('OA')
+ d.delete(b'IA')
+ del d[b'OA']
+ assert 0 == d.has_key(b'IA')
+ assert 0 == d.has_key(b'OA')
assert len(d) == l-2
values = []
@@ -127,18 +122,18 @@ class DBShelveTestCase(unittest.TestCase):
for key, value in items:
self.checkrec(key, value)
- assert d.get('bad key') == None
- assert d.get('bad key', None) == None
- assert d.get('bad key', 'a string') == 'a string'
- assert d.get('bad key', [1, 2, 3]) == [1, 2, 3]
+ assert d.get(b'bad key') == None
+ assert d.get(b'bad key', None) == None
+ assert d.get(b'bad key', b'a string') == b'a string'
+ assert d.get(b'bad key', [1, 2, 3]) == [1, 2, 3]
d.set_get_returns_none(0)
- self.assertRaises(db.DBNotFoundError, d.get, 'bad key')
+ self.assertRaises(db.DBNotFoundError, d.get, b'bad key')
d.set_get_returns_none(1)
- d.put('new key', 'new data')
- assert d.get('new key') == 'new data'
- assert d['new key'] == 'new data'
+ d.put(b'new key', b'new data')
+ assert d.get(b'new key') == b'new data'
+ assert d[b'new key'] == b'new data'
@@ -156,7 +151,7 @@ class DBShelveTestCase(unittest.TestCase):
while rec is not None:
count = count + 1
if verbose:
- print(rec)
+ print(repr(rec))
key, value = rec
self.checkrec(key, value)
rec = c.next()
@@ -177,34 +172,32 @@ class DBShelveTestCase(unittest.TestCase):
assert count == len(d)
- c.set('SS')
+ c.set(b'SS')
key, value = c.current()
self.checkrec(key, value)
del c
-
-
def checkrec(self, key, value):
- x = key[1]
- if key[0] == 'S':
- assert type(value) == StringType
- assert value == 10 * x
+ x = key[1:]
+ if key[0:1] == b'S':
+ self.assertEquals(type(value), str)
+ self.assertEquals(value, 10 * x.decode("ascii"))
- elif key[0] == 'I':
- assert type(value) == IntType
- assert value == ord(x)
+ elif key[0:1] == b'I':
+ self.assertEquals(type(value), int)
+ self.assertEquals(value, ord(x))
- elif key[0] == 'L':
- assert type(value) == ListType
- assert value == [x] * 10
+ elif key[0:1] == b'L':
+ self.assertEquals(type(value), list)
+ self.assertEquals(value, [x.decode("ascii")] * 10)
- elif key[0] == 'O':
- assert value.S == 10 * x
- assert value.I == ord(x)
- assert value.L == [x] * 10
+ elif key[0:1] == b'O':
+ self.assertEquals(value.S, 10 * x.decode("ascii"))
+ self.assertEquals(value.I, ord(x))
+ self.assertEquals(value.L, [x.decode("ascii")] * 10)
else:
- raise AssertionError, 'Unknown key type, fix the test'
+ self.fail('Unknown key type, fix the test')
#----------------------------------------------------------------------