1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
#!/usr/bin/python
# Author: David Goodger
# Contact: goodger@users.sourceforge.net
# Revision: $Revision: 1.13 $
# Date: $Date: 2004/12/23 16:40:35 $
# Copyright: This module has been placed in the public domain.
"""
All modules named 'test_*.py' in the current directory, and recursively in
subdirectories (packages) called 'test_*', are loaded and test suites within
are run.
"""
import time
# Start point for actual elapsed time, including imports
# and setup outside of unittest.
start = time.time()
import sys
import os
import docutils
class Tee:
"""Write to a file and a stream (default: stdout) simultaneously."""
def __init__(self, filename, stream=sys.__stdout__):
self.file = open(filename, 'w')
self.stream = stream
def write(self, string):
self.stream.write(string)
self.file.write(string)
def flush(self):
self.stream.flush()
self.file.flush()
def pformat(suite):
step = 4
suitestr = repr(suite).replace('=[<', '=[\n<').replace(', ', ',\n')
indent = 0
output = []
for line in suitestr.splitlines():
output.append(' ' * indent + line)
if line[-1:] == '[':
indent += step
else:
if line [-5:] == ']>]>,':
indent -= step * 2
elif line[-3:] == ']>,':
indent -= step
return '\n'.join(output)
# must redirect stderr *before* first import of unittest
sys.stdout = sys.stderr = Tee('alltests.out')
import package_unittest
print ('Testing Docutils %s with Python %s on %s at %s'
% (docutils.__version__, sys.version.split()[0],
time.strftime('%Y-%m-%d'), time.strftime('%H:%M:%S')))
sys.stdout.flush()
path, script = os.path.split(sys.argv[0])
suite = package_unittest.loadTestModules(path, 'test_', packages=1)
sys.stdout.flush()
package_unittest.main(suite)
#if package_unittest.verbosity > 1:
# print >>sys.stderr, pformat(suite) # check the test suite
finish = time.time()
print 'Elapsed time: %.3f seconds' % (finish - start)
|