100 lines
3.1 KiB
Python
100 lines
3.1 KiB
Python
|
"""TestCases for using the DB.join and DBCursor.join_item methods.
|
||
|
"""
|
||
|
|
||
|
import os
|
||
|
|
||
|
import unittest
|
||
|
|
||
|
from test_all import db, dbshelve, test_support, verbose, \
|
||
|
get_new_environment_path, get_new_database_path
|
||
|
|
||
|
#----------------------------------------------------------------------
|
||
|
|
||
|
ProductIndex = [
|
||
|
('apple', "Convenience Store"),
|
||
|
('blueberry', "Farmer's Market"),
|
||
|
('shotgun', "S-Mart"), # Aisle 12
|
||
|
('pear', "Farmer's Market"),
|
||
|
('chainsaw', "S-Mart"), # "Shop smart. Shop S-Mart!"
|
||
|
('strawberry', "Farmer's Market"),
|
||
|
]
|
||
|
|
||
|
ColorIndex = [
|
||
|
('blue', "blueberry"),
|
||
|
('red', "apple"),
|
||
|
('red', "chainsaw"),
|
||
|
('red', "strawberry"),
|
||
|
('yellow', "peach"),
|
||
|
('yellow', "pear"),
|
||
|
('black', "shotgun"),
|
||
|
]
|
||
|
|
||
|
class JoinTestCase(unittest.TestCase):
|
||
|
keytype = ''
|
||
|
|
||
|
def setUp(self):
|
||
|
self.filename = self.__class__.__name__ + '.db'
|
||
|
self.homeDir = get_new_environment_path()
|
||
|
self.env = db.DBEnv()
|
||
|
self.env.open(self.homeDir, db.DB_CREATE | db.DB_INIT_MPOOL | db.DB_INIT_LOCK )
|
||
|
|
||
|
def tearDown(self):
|
||
|
self.env.close()
|
||
|
test_support.rmtree(self.homeDir)
|
||
|
|
||
|
def test01_join(self):
|
||
|
if verbose:
|
||
|
print '\n', '-=' * 30
|
||
|
print "Running %s.test01_join..." % \
|
||
|
self.__class__.__name__
|
||
|
|
||
|
# create and populate primary index
|
||
|
priDB = db.DB(self.env)
|
||
|
priDB.open(self.filename, "primary", db.DB_BTREE, db.DB_CREATE)
|
||
|
map(lambda t, priDB=priDB: priDB.put(*t), ProductIndex)
|
||
|
|
||
|
# create and populate secondary index
|
||
|
secDB = db.DB(self.env)
|
||
|
secDB.set_flags(db.DB_DUP | db.DB_DUPSORT)
|
||
|
secDB.open(self.filename, "secondary", db.DB_BTREE, db.DB_CREATE)
|
||
|
map(lambda t, secDB=secDB: secDB.put(*t), ColorIndex)
|
||
|
|
||
|
sCursor = None
|
||
|
jCursor = None
|
||
|
try:
|
||
|
# lets look up all of the red Products
|
||
|
sCursor = secDB.cursor()
|
||
|
# Don't do the .set() in an assert, or you can get a bogus failure
|
||
|
# when running python -O
|
||
|
tmp = sCursor.set('red')
|
||
|
self.assertTrue(tmp)
|
||
|
|
||
|
# FIXME: jCursor doesn't properly hold a reference to its
|
||
|
# cursors, if they are closed before jcursor is used it
|
||
|
# can cause a crash.
|
||
|
jCursor = priDB.join([sCursor])
|
||
|
|
||
|
if jCursor.get(0) != ('apple', "Convenience Store"):
|
||
|
self.fail("join cursor positioned wrong")
|
||
|
if jCursor.join_item() != 'chainsaw':
|
||
|
self.fail("DBCursor.join_item returned wrong item")
|
||
|
if jCursor.get(0)[0] != 'strawberry':
|
||
|
self.fail("join cursor returned wrong thing")
|
||
|
if jCursor.get(0): # there were only three red items to return
|
||
|
self.fail("join cursor returned too many items")
|
||
|
finally:
|
||
|
if jCursor:
|
||
|
jCursor.close()
|
||
|
if sCursor:
|
||
|
sCursor.close()
|
||
|
priDB.close()
|
||
|
secDB.close()
|
||
|
|
||
|
|
||
|
def test_suite():
|
||
|
suite = unittest.TestSuite()
|
||
|
|
||
|
suite.addTest(unittest.makeSuite(JoinTestCase))
|
||
|
|
||
|
return suite
|