mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 21:51:50 +00:00 
			
		
		
		
	 b558a2e13a
			
		
	
	
		b558a2e13a
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r61143 | barry.warsaw | 2008-03-01 03:23:38 +0100 (Sat, 01 Mar 2008) | 2 lines Bump to version 2.6a1 ........ r61144 | barry.warsaw | 2008-03-01 03:26:42 +0100 (Sat, 01 Mar 2008) | 1 line bump idle version number ........ r61146 | fred.drake | 2008-03-01 03:45:07 +0100 (Sat, 01 Mar 2008) | 2 lines fix typo ........ r61147 | barry.warsaw | 2008-03-01 03:53:36 +0100 (Sat, 01 Mar 2008) | 1 line Add date to NEWS ........ r61150 | barry.warsaw | 2008-03-01 04:00:52 +0100 (Sat, 01 Mar 2008) | 1 line Give IDLE a release date ........ r61151 | barry.warsaw | 2008-03-01 04:15:20 +0100 (Sat, 01 Mar 2008) | 1 line More copyright year and version number bumps ........ r61157 | barry.warsaw | 2008-03-01 18:11:41 +0100 (Sat, 01 Mar 2008) | 2 lines Set things up for 2.6a2. ........ r61165 | georg.brandl | 2008-03-02 07:28:16 +0100 (Sun, 02 Mar 2008) | 2 lines It's 2.6 now. ........ r61166 | georg.brandl | 2008-03-02 07:32:32 +0100 (Sun, 02 Mar 2008) | 2 lines Update year. ........ r61167 | georg.brandl | 2008-03-02 07:44:08 +0100 (Sun, 02 Mar 2008) | 2 lines Make patchlevel print out the release if called as a script. ........ r61168 | georg.brandl | 2008-03-02 07:45:40 +0100 (Sun, 02 Mar 2008) | 2 lines New default basename for HTML help files. ........ r61170 | raymond.hettinger | 2008-03-02 11:59:31 +0100 (Sun, 02 Mar 2008) | 1 line Finish-up docs for combinations() and permutations() in itertools. ........ r61171 | raymond.hettinger | 2008-03-02 12:17:51 +0100 (Sun, 02 Mar 2008) | 1 line Tighten example code. ........ r61172 | raymond.hettinger | 2008-03-02 12:57:16 +0100 (Sun, 02 Mar 2008) | 1 line Simplify code for itertools.product(). ........ r61173 | raymond.hettinger | 2008-03-02 13:02:19 +0100 (Sun, 02 Mar 2008) | 1 line Handle 0-tuples which can be singletons. ........ r61176 | georg.brandl | 2008-03-02 14:41:39 +0100 (Sun, 02 Mar 2008) | 2 lines Make clear that the constants are strings. ........ r61177 | georg.brandl | 2008-03-02 15:15:04 +0100 (Sun, 02 Mar 2008) | 2 lines Fix factual error. ........ r61183 | gregory.p.smith | 2008-03-02 21:00:53 +0100 (Sun, 02 Mar 2008) | 4 lines Modify import of test_support so that the code can also be used with a stand alone distribution of bsddb that includes its own small copy of test_support for the needed functionality on older pythons. ........
		
			
				
	
	
		
			85 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| import shutil
 | |
| import sys, os
 | |
| import unittest
 | |
| import tempfile
 | |
| 
 | |
| try:
 | |
|     # For Pythons w/distutils pybsddb
 | |
|     from bsddb3 import db, dbobj
 | |
| except ImportError:
 | |
|     # For Python 2.3
 | |
|     from bsddb import db, dbobj
 | |
| 
 | |
| try:
 | |
|     from bsddb3 import test_support
 | |
| except ImportError:
 | |
|     from test import test_support
 | |
| 
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| class dbobjTestCase(unittest.TestCase):
 | |
|     """Verify that dbobj.DB and dbobj.DBEnv work properly"""
 | |
|     db_name = 'test-dbobj.db'
 | |
| 
 | |
|     def setUp(self):
 | |
|         homeDir = os.path.join(tempfile.gettempdir(), 'db_home%d'%os.getpid())
 | |
|         self.homeDir = homeDir
 | |
|         try: os.mkdir(homeDir)
 | |
|         except os.error: pass
 | |
| 
 | |
|     def tearDown(self):
 | |
|         if hasattr(self, 'db'):
 | |
|             del self.db
 | |
|         if hasattr(self, 'env'):
 | |
|             del self.env
 | |
|         test_support.rmtree(self.homeDir)
 | |
| 
 | |
|     def test01_both(self):
 | |
|         class TestDBEnv(dbobj.DBEnv): pass
 | |
|         class TestDB(dbobj.DB):
 | |
|             def put(self, key, *args, **kwargs):
 | |
|                 key = key.decode("ascii").upper().encode("ascii")
 | |
|                 # call our parent classes put method with an upper case key
 | |
|                 return dbobj.DB.put(self, key, *args, **kwargs)
 | |
|         self.env = TestDBEnv()
 | |
|         self.env.open(self.homeDir, db.DB_CREATE | db.DB_INIT_MPOOL)
 | |
|         self.db = TestDB(self.env)
 | |
|         self.db.open(self.db_name, db.DB_HASH, db.DB_CREATE)
 | |
|         self.db.put(b'spam', b'eggs')
 | |
|         assert self.db.get(b'spam') == None, \
 | |
|                "overridden dbobj.DB.put() method failed [1]"
 | |
|         assert self.db.get(b'SPAM') == b'eggs', \
 | |
|                "overridden dbobj.DB.put() method failed [2]"
 | |
|         self.db.close()
 | |
|         self.env.close()
 | |
| 
 | |
|     def test02_dbobj_dict_interface(self):
 | |
|         self.env = dbobj.DBEnv()
 | |
|         self.env.open(self.homeDir, db.DB_CREATE | db.DB_INIT_MPOOL)
 | |
|         self.db = dbobj.DB(self.env)
 | |
|         self.db.open(self.db_name+'02', db.DB_HASH, db.DB_CREATE)
 | |
|         # __setitem__
 | |
|         self.db[b'spam'] = b'eggs'
 | |
|         # __len__
 | |
|         assert len(self.db) == 1
 | |
|         # __getitem__
 | |
|         assert self.db[b'spam'] == b'eggs'
 | |
|         # __del__
 | |
|         del self.db[b'spam']
 | |
|         assert self.db.get(b'spam') == None, "dbobj __del__ failed"
 | |
|         self.db.close()
 | |
|         self.env.close()
 | |
| 
 | |
|     def test03_dbobj_type_before_open(self):
 | |
|         # Ensure this doesn't cause a segfault.
 | |
|         self.assertRaises(db.DBInvalidArgError, db.DB().type)
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| def test_suite():
 | |
|     return unittest.makeSuite(dbobjTestCase)
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     unittest.main(defaultTest='test_suite')
 |