| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 1 | # Test driver for bsddb package. | 
|  | 2 | """ | 
|  | 3 | Run all test cases. | 
|  | 4 | """ | 
| Neal Norwitz | 6057b2e | 2008-02-24 18:47:03 +0000 | [diff] [blame] | 5 | import os | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 6 | import sys | 
| Neal Norwitz | 6057b2e | 2008-02-24 18:47:03 +0000 | [diff] [blame] | 7 | import tempfile | 
| Neal Norwitz | 41ada16 | 2008-01-27 17:13:07 +0000 | [diff] [blame] | 8 | import time | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 9 | import unittest | 
| R. David Murray | 3db8a34 | 2009-03-30 23:05:48 +0000 | [diff] [blame] | 10 | from test.test_support import (requires, verbose, run_unittest, unlink, rmtree, | 
|  | 11 | import_module) | 
|  | 12 |  | 
| R. David Murray | 597ebab | 2009-03-31 18:32:17 +0000 | [diff] [blame] | 13 | # Skip test if _bsddb module was not built. | 
|  | 14 | import_module('_bsddb') | 
| Ezio Melotti | 5d62cfe | 2010-02-02 08:37:35 +0000 | [diff] [blame^] | 15 | # Silence Py3k warning | 
|  | 16 | import_module('bsddb', deprecated=True) | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 17 |  | 
| Barry Warsaw | 0a26235 | 2002-12-30 20:53:18 +0000 | [diff] [blame] | 18 | # When running as a script instead of within the regrtest framework, skip the | 
|  | 19 | # requires test, since it's obvious we want to run them. | 
| Collin Winter | c2898c5 | 2007-04-25 17:29:52 +0000 | [diff] [blame] | 20 | if __name__ != '__main__': | 
| Barry Warsaw | 0a26235 | 2002-12-30 20:53:18 +0000 | [diff] [blame] | 21 | requires('bsddb') | 
|  | 22 |  | 
|  | 23 | verbose = False | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 24 | if 'verbose' in sys.argv: | 
| Barry Warsaw | 0a26235 | 2002-12-30 20:53:18 +0000 | [diff] [blame] | 25 | verbose = True | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 26 | sys.argv.remove('verbose') | 
|  | 27 |  | 
|  | 28 | if 'silent' in sys.argv:  # take care of old flag, just in case | 
| Barry Warsaw | 0a26235 | 2002-12-30 20:53:18 +0000 | [diff] [blame] | 29 | verbose = False | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 30 | sys.argv.remove('silent') | 
|  | 31 |  | 
|  | 32 |  | 
| Neal Norwitz | 41ada16 | 2008-01-27 17:13:07 +0000 | [diff] [blame] | 33 | class TimingCheck(unittest.TestCase): | 
|  | 34 |  | 
|  | 35 | """This class is not a real test.  Its purpose is to print a message | 
|  | 36 | periodically when the test runs slowly.  This will prevent the buildbots | 
|  | 37 | from timing out on slow machines.""" | 
|  | 38 |  | 
|  | 39 | # How much time in seconds before printing a 'Still working' message. | 
|  | 40 | # Since this is run at most once between each test module, use a smaller | 
|  | 41 | # interval than other tests. | 
|  | 42 | _PRINT_WORKING_MSG_INTERVAL = 4 * 60 | 
|  | 43 |  | 
|  | 44 | # next_time is used as a global variable that survives each instance. | 
|  | 45 | # This is necessary since a new instance will be created for each test. | 
|  | 46 | next_time = time.time() + _PRINT_WORKING_MSG_INTERVAL | 
|  | 47 |  | 
|  | 48 | def testCheckElapsedTime(self): | 
|  | 49 | # Print still working message since these tests can be really slow. | 
|  | 50 | now = time.time() | 
|  | 51 | if self.next_time <= now: | 
|  | 52 | TimingCheck.next_time = now + self._PRINT_WORKING_MSG_INTERVAL | 
|  | 53 | sys.__stdout__.write('  test_bsddb3 still working, be patient...\n') | 
|  | 54 | sys.__stdout__.flush() | 
|  | 55 |  | 
|  | 56 |  | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 57 | # For invocation through regrtest | 
|  | 58 | def test_main(): | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 59 | from bsddb import db | 
| Gregory P. Smith | 8107290 | 2008-05-25 07:14:09 +0000 | [diff] [blame] | 60 | from bsddb.test import test_all | 
| Jesus Cea | dbd2f6d | 2008-05-27 13:26:02 +0000 | [diff] [blame] | 61 | test_all.set_test_path_prefix(os.path.join(tempfile.gettempdir(), | 
|  | 62 | 'z-test_bsddb3-%s' % | 
|  | 63 | os.getpid())) | 
| Gregory P. Smith | 8107290 | 2008-05-25 07:14:09 +0000 | [diff] [blame] | 64 | # Please leave this print in, having this show up in the buildbots | 
|  | 65 | # makes diagnosing problems a lot easier. | 
|  | 66 | print >>sys.stderr, db.DB_VERSION_STRING | 
| Jesus Cea | dbd2f6d | 2008-05-27 13:26:02 +0000 | [diff] [blame] | 67 | print >>sys.stderr, 'Test path prefix: ', test_all.get_test_path_prefix() | 
| Gregory P. Smith | 8107290 | 2008-05-25 07:14:09 +0000 | [diff] [blame] | 68 | try: | 
|  | 69 | run_unittest(test_all.suite(module_prefix='bsddb.test.', | 
|  | 70 | timing_check=TimingCheck)) | 
|  | 71 | finally: | 
|  | 72 | # The only reason to remove db_home is in case if there is an old | 
|  | 73 | # one lying around.  This might be by a different user, so just | 
|  | 74 | # ignore errors.  We should always make a unique name now. | 
|  | 75 | try: | 
| Jesus Cea | dbd2f6d | 2008-05-27 13:26:02 +0000 | [diff] [blame] | 76 | test_all.remove_test_path_directory() | 
| Gregory P. Smith | 8107290 | 2008-05-25 07:14:09 +0000 | [diff] [blame] | 77 | except: | 
|  | 78 | pass | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 79 |  | 
| Gregory P. Smith | 8107290 | 2008-05-25 07:14:09 +0000 | [diff] [blame] | 80 |  | 
|  | 81 | if __name__ == '__main__': | 
| Collin Winter | c2898c5 | 2007-04-25 17:29:52 +0000 | [diff] [blame] | 82 | test_main() |