summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorGregory P. Smith <greg@mad-scientist.com>2007-11-01 21:55:08 (GMT)
committerGregory P. Smith <greg@mad-scientist.com>2007-11-01 21:55:08 (GMT)
commit568065e9d152ed495775a767968a8749fe78a75c (patch)
tree1df5f9cc6364ed2f4183c65cd3197e2e30fce5dc /Lib
parent48decfe7403bc1dda386cc469b28236c8de018d2 (diff)
downloadcpython-568065e9d152ed495775a767968a8749fe78a75c.zip
cpython-568065e9d152ed495775a767968a8749fe78a75c.tar.gz
cpython-568065e9d152ed495775a767968a8749fe78a75c.tar.bz2
Fixes issue1371 and reenables those tests.
Merge r58757 and r58758 from trunk. Undoes incorrect dbtables fix and errant strdup introduced as described below: r58757 | gregory.p.smith | 2007-11-01 14:08:14 -0700 (Thu, 01 Nov 2007) | 4 lines Fix bug introduced in revision 58385. Database keys could no longer have NULL bytes in them. Replace the errant strdup with a malloc+memcpy. Adds a unit test for the correct behavior. r58758 | gregory.p.smith | 2007-11-01 14:15:36 -0700 (Thu, 01 Nov 2007) | 3 lines Undo revision 58533 58534 fixes. Those were a workaround for a problem introduced by 58385.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/bsddb/dbtables.py5
-rw-r--r--Lib/bsddb/test/test_misc.py53
2 files changed, 38 insertions, 20 deletions
diff --git a/Lib/bsddb/dbtables.py b/Lib/bsddb/dbtables.py
index 85a13ff..06fcf8a 100644
--- a/Lib/bsddb/dbtables.py
+++ b/Lib/bsddb/dbtables.py
@@ -362,12 +362,11 @@ class bsdTableDB :
unique = 0
while not unique:
# Generate a random 64-bit row ID string
- # (note: this code has <64 bits of randomness
+ # (note: might have <64 bits of randomness
# but it's plenty for our database id needs!)
- # We must ensure that no null bytes are in the id value.
blist = []
for x in range(_rowid_str_len):
- blist.append(random.randint(1,255))
+ blist.append(random.randint(0,255))
newid = bytes(blist)
# Guarantee uniqueness by adding this key to the database
diff --git a/Lib/bsddb/test/test_misc.py b/Lib/bsddb/test/test_misc.py
index 5223180..b3248ce 100644
--- a/Lib/bsddb/test/test_misc.py
+++ b/Lib/bsddb/test/test_misc.py
@@ -11,7 +11,7 @@ try:
# For Pythons w/distutils pybsddb
from bsddb3 import db, dbshelve, hashopen
except ImportError:
- # For Python 2.3
+ # For the bundled bsddb
from bsddb import db, dbshelve, hashopen
#----------------------------------------------------------------------
@@ -28,10 +28,10 @@ class MiscTestCase(unittest.TestCase):
pass
shutil.rmtree(self.homeDir)
-## def test01_badpointer(self):
-## dbs = dbshelve.open(self.filename)
-## dbs.close()
-## self.assertRaises(db.DBError, dbs.get, "foo")
+ def test01_badpointer(self):
+ dbs = dbshelve.open(self.filename)
+ dbs.close()
+ self.assertRaises(db.DBError, dbs.get, b"foo")
def test02_db_home(self):
env = db.DBEnv()
@@ -53,18 +53,37 @@ class MiscTestCase(unittest.TestCase):
# The problem was that make_key_dbt() was not allocating a copy of
# string keys but FREE_DBT() was always being told to free it when the
# database was opened with DB_THREAD.
-## def test04_double_free_make_key_dbt(self):
-## try:
-## db1 = db.DB()
-## db1.open(self.filename, None, db.DB_BTREE,
-## db.DB_CREATE | db.DB_THREAD)
-
-## curs = db1.cursor()
-## t = curs.get(b"/foo", db.DB_SET)
-## # double free happened during exit from DBC_get
-## finally:
-## db1.close()
-## os.unlink(self.filename)
+ def test04_double_free_make_key_dbt(self):
+ try:
+ db1 = db.DB()
+ db1.open(self.filename, None, db.DB_BTREE,
+ db.DB_CREATE | db.DB_THREAD)
+
+ curs = db1.cursor()
+ t = curs.get(b"/foo", db.DB_SET)
+ # double free happened during exit from DBC_get
+ finally:
+ db1.close()
+ os.unlink(self.filename)
+
+ def test05_key_with_null_bytes(self):
+ try:
+ db1 = db.DB()
+ db1.open(self.filename, None, db.DB_HASH, db.DB_CREATE)
+ db1[b'a'] = b'eh?'
+ db1[b'a\x00'] = b'eh zed.'
+ db1[b'a\x00a'] = b'eh zed eh?'
+ db1[b'aaa'] = b'eh eh eh!'
+ keys = db1.keys()
+ keys.sort()
+ self.assertEqual([b'a', b'a\x00', b'a\x00a', b'aaa'], keys)
+ self.assertEqual(db1[b'a'], b'eh?')
+ self.assertEqual(db1[b'a\x00'], b'eh zed.')
+ self.assertEqual(db1[b'a\x00a'], b'eh zed eh?')
+ self.assertEqual(db1[b'aaa'], b'eh eh eh!')
+ finally:
+ db1.close()
+ os.unlink(self.filename)
#----------------------------------------------------------------------