164
189
self.unsupported = {}
166
191
self._overall_start_time = time.time()
168
def _extractBenchmarkTime(self, testCase):
192
self._strict = strict
194
def stopTestRun(self):
197
stopTime = time.time()
198
timeTaken = stopTime - self.startTime
199
# GZ 2010-07-19: Seems testtools has no printErrors method, and though
200
# the parent class method is similar have to duplicate
201
self._show_list('ERROR', self.errors)
202
self._show_list('FAIL', self.failures)
203
self.stream.write(self.sep2)
204
self.stream.write("%s %d test%s in %.3fs\n\n" % (actionTaken,
205
run, run != 1 and "s" or "", timeTaken))
206
if not self.wasSuccessful():
207
self.stream.write("FAILED (")
208
failed, errored = map(len, (self.failures, self.errors))
210
self.stream.write("failures=%d" % failed)
212
if failed: self.stream.write(", ")
213
self.stream.write("errors=%d" % errored)
214
if self.known_failure_count:
215
if failed or errored: self.stream.write(", ")
216
self.stream.write("known_failure_count=%d" %
217
self.known_failure_count)
218
self.stream.write(")\n")
220
if self.known_failure_count:
221
self.stream.write("OK (known_failures=%d)\n" %
222
self.known_failure_count)
224
self.stream.write("OK\n")
225
if self.skip_count > 0:
226
skipped = self.skip_count
227
self.stream.write('%d test%s skipped\n' %
228
(skipped, skipped != 1 and "s" or ""))
230
for feature, count in sorted(self.unsupported.items()):
231
self.stream.write("Missing feature '%s' skipped %d tests.\n" %
234
ok = self.wasStrictlySuccessful()
236
ok = self.wasSuccessful()
237
if TestCase._first_thread_leaker_id:
239
'%s is leaking threads among %d leaking tests.\n' % (
240
TestCase._first_thread_leaker_id,
241
TestCase._leaking_threads_tests))
242
# We don't report the main thread as an active one.
244
'%d non-main threads were left active in the end.\n'
245
% (TestCase._active_threads - 1))
247
def getDescription(self, test):
250
def _extractBenchmarkTime(self, testCase, details=None):
169
251
"""Add a benchmark time for the current test case."""
252
if details and 'benchtime' in details:
253
return float(''.join(details['benchtime'].iter_bytes()))
170
254
return getattr(testCase, "_benchtime", None)
172
256
def _elapsedTestTimeString(self):
465
548
return '%s%s' % (indent, err[1])
467
550
def report_error(self, test, err):
468
self.stream.writeln('ERROR %s\n%s'
551
self.stream.write('ERROR %s\n%s\n'
469
552
% (self._testTimeString(test),
470
553
self._error_summary(err)))
472
555
def report_failure(self, test, err):
473
self.stream.writeln(' FAIL %s\n%s'
556
self.stream.write(' FAIL %s\n%s\n'
474
557
% (self._testTimeString(test),
475
558
self._error_summary(err)))
477
560
def report_known_failure(self, test, err):
478
self.stream.writeln('XFAIL %s\n%s'
561
self.stream.write('XFAIL %s\n%s\n'
479
562
% (self._testTimeString(test),
480
563
self._error_summary(err)))
482
565
def report_success(self, test):
483
self.stream.writeln(' OK %s' % self._testTimeString(test))
566
self.stream.write(' OK %s\n' % self._testTimeString(test))
484
567
for bench_called, stats in getattr(test, '_benchcalls', []):
485
self.stream.writeln('LSProf output for %s(%s, %s)' % bench_called)
568
self.stream.write('LSProf output for %s(%s, %s)\n' % bench_called)
486
569
stats.pprint(file=self.stream)
487
570
# flush the stream so that we get smooth output. This verbose mode is
488
571
# used to show the output in PQM.
489
572
self.stream.flush()
491
574
def report_skip(self, test, reason):
492
self.stream.writeln(' SKIP %s\n%s'
575
self.stream.write(' SKIP %s\n%s\n'
493
576
% (self._testTimeString(test), reason))
495
def report_not_applicable(self, test, skip_excinfo):
496
self.stream.writeln(' N/A %s\n%s'
497
% (self._testTimeString(test),
498
self._error_summary(skip_excinfo)))
578
def report_not_applicable(self, test, reason):
579
self.stream.write(' N/A %s\n %s\n'
580
% (self._testTimeString(test), reason))
500
582
def report_unsupported(self, test, feature):
501
583
"""test cannot be run because feature is missing."""
502
self.stream.writeln("NODEP %s\n The feature '%s' is not available."
584
self.stream.write("NODEP %s\n The feature '%s' is not available.\n"
503
585
%(self._testTimeString(test), feature))
513
595
bench_history=None,
597
result_decorators=None,
516
self.stream = unittest._WritelnDecorator(stream)
599
"""Create a TextTestRunner.
601
:param result_decorators: An optional list of decorators to apply
602
to the result object being used by the runner. Decorators are
603
applied left to right - the first element in the list is the
606
# stream may know claim to know to write unicode strings, but in older
607
# pythons this goes sufficiently wrong that it is a bad idea. (
608
# specifically a built in file with encoding 'UTF-8' will still try
609
# to encode using ascii.
610
new_encoding = osutils.get_terminal_encoding()
611
codec = codecs.lookup(new_encoding)
612
if type(codec) is tuple:
616
encode = codec.encode
617
stream = osutils.UnicodeOrBytesToBytesWriter(encode, stream)
618
stream.encoding = new_encoding
517
620
self.descriptions = descriptions
518
621
self.verbosity = verbosity
519
622
self._bench_history = bench_history
520
self.list_only = list_only
623
self._strict = strict
624
self._result_decorators = result_decorators or []
522
626
def run(self, test):
523
627
"Run the given test case or test suite."
524
startTime = time.time()
525
628
if self.verbosity == 1:
526
629
result_class = TextTestResult
527
630
elif self.verbosity >= 2:
528
631
result_class = VerboseTestResult
529
result = result_class(self.stream,
632
original_result = result_class(self.stream,
530
633
self.descriptions,
532
635
bench_history=self._bench_history,
533
num_tests=test.countTestCases(),
535
result.stop_early = self.stop_on_failure
536
result.report_starting()
538
if self.verbosity >= 2:
539
self.stream.writeln("Listing tests only ...\n")
541
for t in iter_suite_tests(test):
542
self.stream.writeln("%s" % (t.id()))
544
actionTaken = "Listed"
638
# Signal to result objects that look at stop early policy to stop,
639
original_result.stop_early = self.stop_on_failure
640
result = original_result
641
for decorator in self._result_decorators:
642
result = decorator(result)
643
result.stop_early = self.stop_on_failure
644
result.startTestRun()
547
run = result.testsRun
549
stopTime = time.time()
550
timeTaken = stopTime - startTime
552
self.stream.writeln(result.separator2)
553
self.stream.writeln("%s %d test%s in %.3fs" % (actionTaken,
554
run, run != 1 and "s" or "", timeTaken))
555
self.stream.writeln()
556
if not result.wasSuccessful():
557
self.stream.write("FAILED (")
558
failed, errored = map(len, (result.failures, result.errors))
560
self.stream.write("failures=%d" % failed)
562
if failed: self.stream.write(", ")
563
self.stream.write("errors=%d" % errored)
564
if result.known_failure_count:
565
if failed or errored: self.stream.write(", ")
566
self.stream.write("known_failure_count=%d" %
567
result.known_failure_count)
568
self.stream.writeln(")")
570
if result.known_failure_count:
571
self.stream.writeln("OK (known_failures=%d)" %
572
result.known_failure_count)
574
self.stream.writeln("OK")
575
if result.skip_count > 0:
576
skipped = result.skip_count
577
self.stream.writeln('%d test%s skipped' %
578
(skipped, skipped != 1 and "s" or ""))
579
if result.unsupported:
580
for feature, count in sorted(result.unsupported.items()):
581
self.stream.writeln("Missing feature '%s' skipped %d tests." %
649
# higher level code uses our extended protocol to determine
650
# what exit code to give.
651
return original_result
587
654
def iter_suite_tests(suite):
830
876
# this hook should always be installed
831
877
request._install_hook()
879
def disable_directory_isolation(self):
880
"""Turn off directory isolation checks."""
881
self._directory_isolation = False
883
def enable_directory_isolation(self):
884
"""Enable directory isolation checks."""
885
self._directory_isolation = True
833
887
def _silenceUI(self):
834
888
"""Turn off UI for duration of test"""
835
889
# by default the UI is off; tests can turn it on if they want it.
836
saved = ui.ui_factory
838
ui.ui_factory = saved
839
ui.ui_factory = ui.SilentUIFactory()
840
self.addCleanup(_restore)
890
self.overrideAttr(ui, 'ui_factory', ui.SilentUIFactory())
892
def _check_locks(self):
893
"""Check that all lock take/release actions have been paired."""
894
# We always check for mismatched locks. If a mismatch is found, we
895
# fail unless -Edisable_lock_checks is supplied to selftest, in which
896
# case we just print a warning.
898
acquired_locks = [lock for action, lock in self._lock_actions
899
if action == 'acquired']
900
released_locks = [lock for action, lock in self._lock_actions
901
if action == 'released']
902
broken_locks = [lock for action, lock in self._lock_actions
903
if action == 'broken']
904
# trivially, given the tests for lock acquistion and release, if we
905
# have as many in each list, it should be ok. Some lock tests also
906
# break some locks on purpose and should be taken into account by
907
# considering that breaking a lock is just a dirty way of releasing it.
908
if len(acquired_locks) != (len(released_locks) + len(broken_locks)):
909
message = ('Different number of acquired and '
910
'released or broken locks. (%s, %s + %s)' %
911
(acquired_locks, released_locks, broken_locks))
912
if not self._lock_check_thorough:
913
# Rather than fail, just warn
914
print "Broken test %s: %s" % (self, message)
918
def _track_locks(self):
919
"""Track lock activity during tests."""
920
self._lock_actions = []
921
if 'disable_lock_checks' in selftest_debug_flags:
922
self._lock_check_thorough = False
924
self._lock_check_thorough = True
926
self.addCleanup(self._check_locks)
927
_mod_lock.Lock.hooks.install_named_hook('lock_acquired',
928
self._lock_acquired, None)
929
_mod_lock.Lock.hooks.install_named_hook('lock_released',
930
self._lock_released, None)
931
_mod_lock.Lock.hooks.install_named_hook('lock_broken',
932
self._lock_broken, None)
934
def _lock_acquired(self, result):
935
self._lock_actions.append(('acquired', result))
937
def _lock_released(self, result):
938
self._lock_actions.append(('released', result))
940
def _lock_broken(self, result):
941
self._lock_actions.append(('broken', result))
943
def permit_dir(self, name):
944
"""Permit a directory to be used by this test. See permit_url."""
945
name_transport = _mod_transport.get_transport(name)
946
self.permit_url(name)
947
self.permit_url(name_transport.base)
949
def permit_url(self, url):
950
"""Declare that url is an ok url to use in this test.
952
Do this for memory transports, temporary test directory etc.
954
Do not do this for the current working directory, /tmp, or any other
955
preexisting non isolated url.
957
if not url.endswith('/'):
959
self._bzr_selftest_roots.append(url)
961
def permit_source_tree_branch_repo(self):
962
"""Permit the source tree bzr is running from to be opened.
964
Some code such as bzrlib.version attempts to read from the bzr branch
965
that bzr is executing from (if any). This method permits that directory
966
to be used in the test suite.
968
path = self.get_source_path()
969
self.record_directory_isolation()
972
workingtree.WorkingTree.open(path)
973
except (errors.NotBranchError, errors.NoWorkingTree):
976
self.enable_directory_isolation()
978
def _preopen_isolate_transport(self, transport):
979
"""Check that all transport openings are done in the test work area."""
980
while isinstance(transport, pathfilter.PathFilteringTransport):
981
# Unwrap pathfiltered transports
982
transport = transport.server.backing_transport.clone(
983
transport._filter('.'))
985
# ReadonlySmartTCPServer_for_testing decorates the backing transport
986
# urls it is given by prepending readonly+. This is appropriate as the
987
# client shouldn't know that the server is readonly (or not readonly).
988
# We could register all servers twice, with readonly+ prepending, but
989
# that makes for a long list; this is about the same but easier to
991
if url.startswith('readonly+'):
992
url = url[len('readonly+'):]
993
self._preopen_isolate_url(url)
995
def _preopen_isolate_url(self, url):
996
if not self._directory_isolation:
998
if self._directory_isolation == 'record':
999
self._bzr_selftest_roots.append(url)
1001
# This prevents all transports, including e.g. sftp ones backed on disk
1002
# from working unless they are explicitly granted permission. We then
1003
# depend on the code that sets up test transports to check that they are
1004
# appropriately isolated and enable their use by calling
1005
# self.permit_transport()
1006
if not osutils.is_inside_any(self._bzr_selftest_roots, url):
1007
raise errors.BzrError("Attempt to escape test isolation: %r %r"
1008
% (url, self._bzr_selftest_roots))
1010
def record_directory_isolation(self):
1011
"""Gather accessed directories to permit later access.
1013
This is used for tests that access the branch bzr is running from.
1015
self._directory_isolation = "record"
1017
def start_server(self, transport_server, backing_server=None):
1018
"""Start transport_server for this test.
1020
This starts the server, registers a cleanup for it and permits the
1021
server's urls to be used.
1023
if backing_server is None:
1024
transport_server.start_server()
1026
transport_server.start_server(backing_server)
1027
self.addCleanup(transport_server.stop_server)
1028
# Obtain a real transport because if the server supplies a password, it
1029
# will be hidden from the base on the client side.
1030
t = _mod_transport.get_transport(transport_server.get_url())
1031
# Some transport servers effectively chroot the backing transport;
1032
# others like SFTPServer don't - users of the transport can walk up the
1033
# transport to read the entire backing transport. This wouldn't matter
1034
# except that the workdir tests are given - and that they expect the
1035
# server's url to point at - is one directory under the safety net. So
1036
# Branch operations into the transport will attempt to walk up one
1037
# directory. Chrooting all servers would avoid this but also mean that
1038
# we wouldn't be testing directly against non-root urls. Alternatively
1039
# getting the test framework to start the server with a backing server
1040
# at the actual safety net directory would work too, but this then
1041
# means that the self.get_url/self.get_transport methods would need
1042
# to transform all their results. On balance its cleaner to handle it
1043
# here, and permit a higher url when we have one of these transports.
1044
if t.base.endswith('/work/'):
1045
# we have safety net/test root/work
1046
t = t.clone('../..')
1047
elif isinstance(transport_server,
1048
test_server.SmartTCPServer_for_testing):
1049
# The smart server adds a path similar to work, which is traversed
1050
# up from by the client. But the server is chrooted - the actual
1051
# backing transport is not escaped from, and VFS requests to the
1052
# root will error (because they try to escape the chroot).
1054
while t2.base != t.base:
1057
self.permit_url(t.base)
1059
def _track_transports(self):
1060
"""Install checks for transport usage."""
1061
# TestCase has no safe place it can write to.
1062
self._bzr_selftest_roots = []
1063
# Currently the easiest way to be sure that nothing is going on is to
1064
# hook into bzr dir opening. This leaves a small window of error for
1065
# transport tests, but they are well known, and we can improve on this
1067
bzrdir.BzrDir.hooks.install_named_hook("pre_open",
1068
self._preopen_isolate_transport, "Check bzr directories are safe.")
842
1070
def _ndiff_strings(self, a, b):
843
1071
"""Return ndiff between two strings containing lines.
1306
1585
def _do_skip(self, result, reason):
1307
1586
addSkip = getattr(result, 'addSkip', None)
1308
1587
if not callable(addSkip):
1309
result.addError(self, self.exc_info())
1588
result.addSuccess(result)
1311
1590
addSkip(self, reason)
1313
def run(self, result=None):
1314
if result is None: result = self.defaultTestResult()
1315
for feature in getattr(self, '_test_needs_features', []):
1316
if not feature.available():
1317
result.startTest(self)
1318
if getattr(result, 'addNotSupported', None):
1319
result.addNotSupported(self, feature)
1321
result.addSuccess(self)
1322
result.stopTest(self)
1326
result.startTest(self)
1327
absent_attr = object()
1329
method_name = getattr(self, '_testMethodName', absent_attr)
1330
if method_name is absent_attr:
1332
method_name = getattr(self, '_TestCase__testMethodName')
1333
testMethod = getattr(self, method_name)
1337
if not self._bzr_test_setUp_run:
1339
"test setUp did not invoke "
1340
"bzrlib.tests.TestCase's setUp")
1341
except KeyboardInterrupt:
1343
except TestSkipped, e:
1344
self._do_skip(result, e.args[0])
1348
result.addError(self, self.exc_info())
1355
except self.failureException:
1356
result.addFailure(self, self.exc_info())
1357
except TestSkipped, e:
1359
reason = "No reason given."
1362
self._do_skip(result, reason)
1363
except KeyboardInterrupt:
1366
result.addError(self, self.exc_info())
1370
if not self._bzr_test_tearDown_run:
1372
"test tearDown did not invoke "
1373
"bzrlib.tests.TestCase's tearDown")
1374
except KeyboardInterrupt:
1377
result.addError(self, self.exc_info())
1379
if ok: result.addSuccess(self)
1381
result.stopTest(self)
1383
except TestNotApplicable:
1384
# Not moved from the result [yet].
1386
except KeyboardInterrupt:
1390
absent_attr = object()
1391
for attr_name in self.attrs_to_keep:
1392
attr = getattr(self, attr_name, absent_attr)
1393
if attr is not absent_attr:
1394
saved_attrs[attr_name] = attr
1395
self.__dict__ = saved_attrs
1398
self._bzr_test_tearDown_run = True
1400
self._log_contents = ''
1401
unittest.TestCase.tearDown(self)
1593
def _do_known_failure(self, result, e):
1594
err = sys.exc_info()
1595
addExpectedFailure = getattr(result, 'addExpectedFailure', None)
1596
if addExpectedFailure is not None:
1597
addExpectedFailure(self, err)
1599
result.addSuccess(self)
1602
def _do_not_applicable(self, result, e):
1604
reason = 'No reason given'
1607
addNotApplicable = getattr(result, 'addNotApplicable', None)
1608
if addNotApplicable is not None:
1609
result.addNotApplicable(self, reason)
1611
self._do_skip(result, reason)
1614
def _do_unsupported_or_skip(self, result, e):
1616
addNotSupported = getattr(result, 'addNotSupported', None)
1617
if addNotSupported is not None:
1618
result.addNotSupported(self, reason)
1620
self._do_skip(result, reason)
1403
1622
def time(self, callable, *args, **kwargs):
1404
1623
"""Run callable and accrue the time it takes to the benchmark time.
2836
3204
return iter(self._tests)
3207
def partition_tests(suite, count):
3208
"""Partition suite into count lists of tests."""
3209
# This just assigns tests in a round-robin fashion. On one hand this
3210
# splits up blocks of related tests that might run faster if they shared
3211
# resources, but on the other it avoids assigning blocks of slow tests to
3212
# just one partition. So the slowest partition shouldn't be much slower
3214
partitions = [list() for i in range(count)]
3215
tests = iter_suite_tests(suite)
3216
for partition, test in itertools.izip(itertools.cycle(partitions), tests):
3217
partition.append(test)
3221
def workaround_zealous_crypto_random():
3222
"""Crypto.Random want to help us being secure, but we don't care here.
3224
This workaround some test failure related to the sftp server. Once paramiko
3225
stop using the controversial API in Crypto.Random, we may get rid of it.
3228
from Crypto.Random import atfork
3234
def fork_for_tests(suite):
3235
"""Take suite and start up one runner per CPU by forking()
3237
:return: An iterable of TestCase-like objects which can each have
3238
run(result) called on them to feed tests to result.
3240
concurrency = osutils.local_concurrency()
3242
from subunit import TestProtocolClient, ProtocolTestCase
3243
from subunit.test_results import AutoTimingTestResultDecorator
3244
class TestInOtherProcess(ProtocolTestCase):
3245
# Should be in subunit, I think. RBC.
3246
def __init__(self, stream, pid):
3247
ProtocolTestCase.__init__(self, stream)
3250
def run(self, result):
3252
ProtocolTestCase.run(self, result)
3254
os.waitpid(self.pid, 0)
3256
test_blocks = partition_tests(suite, concurrency)
3257
for process_tests in test_blocks:
3258
process_suite = TestUtil.TestSuite()
3259
process_suite.addTests(process_tests)
3260
c2pread, c2pwrite = os.pipe()
3263
workaround_zealous_crypto_random()
3266
# Leave stderr and stdout open so we can see test noise
3267
# Close stdin so that the child goes away if it decides to
3268
# read from stdin (otherwise its a roulette to see what
3269
# child actually gets keystrokes for pdb etc).
3272
stream = os.fdopen(c2pwrite, 'wb', 1)
3273
subunit_result = AutoTimingTestResultDecorator(
3274
TestProtocolClient(stream))
3275
process_suite.run(subunit_result)
3280
stream = os.fdopen(c2pread, 'rb', 1)
3281
test = TestInOtherProcess(stream, pid)
3286
def reinvoke_for_tests(suite):
3287
"""Take suite and start up one runner per CPU using subprocess().
3289
:return: An iterable of TestCase-like objects which can each have
3290
run(result) called on them to feed tests to result.
3292
concurrency = osutils.local_concurrency()
3294
from subunit import ProtocolTestCase
3295
class TestInSubprocess(ProtocolTestCase):
3296
def __init__(self, process, name):
3297
ProtocolTestCase.__init__(self, process.stdout)
3298
self.process = process
3299
self.process.stdin.close()
3302
def run(self, result):
3304
ProtocolTestCase.run(self, result)
3307
os.unlink(self.name)
3308
# print "pid %d finished" % finished_process
3309
test_blocks = partition_tests(suite, concurrency)
3310
for process_tests in test_blocks:
3311
# ugly; currently reimplement rather than reuses TestCase methods.
3312
bzr_path = os.path.dirname(os.path.dirname(bzrlib.__file__))+'/bzr'
3313
if not os.path.isfile(bzr_path):
3314
# We are probably installed. Assume sys.argv is the right file
3315
bzr_path = sys.argv[0]
3316
bzr_path = [bzr_path]
3317
if sys.platform == "win32":
3318
# if we're on windows, we can't execute the bzr script directly
3319
bzr_path = [sys.executable] + bzr_path
3320
fd, test_list_file_name = tempfile.mkstemp()
3321
test_list_file = os.fdopen(fd, 'wb', 1)
3322
for test in process_tests:
3323
test_list_file.write(test.id() + '\n')
3324
test_list_file.close()
3326
argv = bzr_path + ['selftest', '--load-list', test_list_file_name,
3328
if '--no-plugins' in sys.argv:
3329
argv.append('--no-plugins')
3330
# stderr=subprocess.STDOUT would be ideal, but until we prevent
3331
# noise on stderr it can interrupt the subunit protocol.
3332
process = subprocess.Popen(argv, stdin=subprocess.PIPE,
3333
stdout=subprocess.PIPE,
3334
stderr=subprocess.PIPE,
3336
test = TestInSubprocess(process, test_list_file_name)
3339
os.unlink(test_list_file_name)
3344
class ForwardingResult(unittest.TestResult):
3346
def __init__(self, target):
3347
unittest.TestResult.__init__(self)
3348
self.result = target
3350
def startTest(self, test):
3351
self.result.startTest(test)
3353
def stopTest(self, test):
3354
self.result.stopTest(test)
3356
def startTestRun(self):
3357
self.result.startTestRun()
3359
def stopTestRun(self):
3360
self.result.stopTestRun()
3362
def addSkip(self, test, reason):
3363
self.result.addSkip(test, reason)
3365
def addSuccess(self, test):
3366
self.result.addSuccess(test)
3368
def addError(self, test, err):
3369
self.result.addError(test, err)
3371
def addFailure(self, test, err):
3372
self.result.addFailure(test, err)
3373
ForwardingResult = testtools.ExtendedToOriginalDecorator
3376
class ProfileResult(ForwardingResult):
3377
"""Generate profiling data for all activity between start and success.
3379
The profile data is appended to the test's _benchcalls attribute and can
3380
be accessed by the forwarded-to TestResult.
3382
While it might be cleaner do accumulate this in stopTest, addSuccess is
3383
where our existing output support for lsprof is, and this class aims to
3384
fit in with that: while it could be moved it's not necessary to accomplish
3385
test profiling, nor would it be dramatically cleaner.
3388
def startTest(self, test):
3389
self.profiler = bzrlib.lsprof.BzrProfiler()
3390
# Prevent deadlocks in tests that use lsprof: those tests will
3392
bzrlib.lsprof.BzrProfiler.profiler_block = 0
3393
self.profiler.start()
3394
ForwardingResult.startTest(self, test)
3396
def addSuccess(self, test):
3397
stats = self.profiler.stop()
3399
calls = test._benchcalls
3400
except AttributeError:
3401
test._benchcalls = []
3402
calls = test._benchcalls
3403
calls.append(((test.id(), "", ""), stats))
3404
ForwardingResult.addSuccess(self, test)
3406
def stopTest(self, test):
3407
ForwardingResult.stopTest(self, test)
3408
self.profiler = None
2839
3411
# Controlled by "bzr selftest -E=..." option
3412
# Currently supported:
3413
# -Eallow_debug Will no longer clear debug.debug_flags() so it
3414
# preserves any flags supplied at the command line.
3415
# -Edisable_lock_checks Turns errors in mismatched locks into simple prints
3416
# rather than failing tests. And no longer raise
3417
# LockContention when fctnl locks are not being used
3418
# with proper exclusion rules.
3419
# -Ethreads Will display thread ident at creation/join time to
3420
# help track thread leaks
2840
3421
selftest_debug_flags = set()
3052
3650
test_prefix_alias_registry.register('bp', 'bzrlib.plugins')
3653
def _test_suite_testmod_names():
3654
"""Return the standard list of test module names to test."""
3657
'bzrlib.tests.blackbox',
3658
'bzrlib.tests.commands',
3659
'bzrlib.tests.doc_generate',
3660
'bzrlib.tests.per_branch',
3661
'bzrlib.tests.per_controldir',
3662
'bzrlib.tests.per_controldir_colo',
3663
'bzrlib.tests.per_foreign_vcs',
3664
'bzrlib.tests.per_interrepository',
3665
'bzrlib.tests.per_intertree',
3666
'bzrlib.tests.per_inventory',
3667
'bzrlib.tests.per_interbranch',
3668
'bzrlib.tests.per_lock',
3669
'bzrlib.tests.per_merger',
3670
'bzrlib.tests.per_transport',
3671
'bzrlib.tests.per_tree',
3672
'bzrlib.tests.per_pack_repository',
3673
'bzrlib.tests.per_repository',
3674
'bzrlib.tests.per_repository_chk',
3675
'bzrlib.tests.per_repository_reference',
3676
'bzrlib.tests.per_uifactory',
3677
'bzrlib.tests.per_versionedfile',
3678
'bzrlib.tests.per_workingtree',
3679
'bzrlib.tests.test__annotator',
3680
'bzrlib.tests.test__bencode',
3681
'bzrlib.tests.test__btree_serializer',
3682
'bzrlib.tests.test__chk_map',
3683
'bzrlib.tests.test__dirstate_helpers',
3684
'bzrlib.tests.test__groupcompress',
3685
'bzrlib.tests.test__known_graph',
3686
'bzrlib.tests.test__rio',
3687
'bzrlib.tests.test__simple_set',
3688
'bzrlib.tests.test__static_tuple',
3689
'bzrlib.tests.test__walkdirs_win32',
3690
'bzrlib.tests.test_ancestry',
3691
'bzrlib.tests.test_annotate',
3692
'bzrlib.tests.test_api',
3693
'bzrlib.tests.test_atomicfile',
3694
'bzrlib.tests.test_bad_files',
3695
'bzrlib.tests.test_bisect_multi',
3696
'bzrlib.tests.test_branch',
3697
'bzrlib.tests.test_branchbuilder',
3698
'bzrlib.tests.test_btree_index',
3699
'bzrlib.tests.test_bugtracker',
3700
'bzrlib.tests.test_bundle',
3701
'bzrlib.tests.test_bzrdir',
3702
'bzrlib.tests.test__chunks_to_lines',
3703
'bzrlib.tests.test_cache_utf8',
3704
'bzrlib.tests.test_chk_map',
3705
'bzrlib.tests.test_chk_serializer',
3706
'bzrlib.tests.test_chunk_writer',
3707
'bzrlib.tests.test_clean_tree',
3708
'bzrlib.tests.test_cleanup',
3709
'bzrlib.tests.test_cmdline',
3710
'bzrlib.tests.test_commands',
3711
'bzrlib.tests.test_commit',
3712
'bzrlib.tests.test_commit_merge',
3713
'bzrlib.tests.test_config',
3714
'bzrlib.tests.test_conflicts',
3715
'bzrlib.tests.test_counted_lock',
3716
'bzrlib.tests.test_crash',
3717
'bzrlib.tests.test_decorators',
3718
'bzrlib.tests.test_delta',
3719
'bzrlib.tests.test_debug',
3720
'bzrlib.tests.test_deprecated_graph',
3721
'bzrlib.tests.test_diff',
3722
'bzrlib.tests.test_directory_service',
3723
'bzrlib.tests.test_dirstate',
3724
'bzrlib.tests.test_email_message',
3725
'bzrlib.tests.test_eol_filters',
3726
'bzrlib.tests.test_errors',
3727
'bzrlib.tests.test_export',
3728
'bzrlib.tests.test_extract',
3729
'bzrlib.tests.test_fetch',
3730
'bzrlib.tests.test_fixtures',
3731
'bzrlib.tests.test_fifo_cache',
3732
'bzrlib.tests.test_filters',
3733
'bzrlib.tests.test_ftp_transport',
3734
'bzrlib.tests.test_foreign',
3735
'bzrlib.tests.test_generate_docs',
3736
'bzrlib.tests.test_generate_ids',
3737
'bzrlib.tests.test_globbing',
3738
'bzrlib.tests.test_gpg',
3739
'bzrlib.tests.test_graph',
3740
'bzrlib.tests.test_groupcompress',
3741
'bzrlib.tests.test_hashcache',
3742
'bzrlib.tests.test_help',
3743
'bzrlib.tests.test_hooks',
3744
'bzrlib.tests.test_http',
3745
'bzrlib.tests.test_http_response',
3746
'bzrlib.tests.test_https_ca_bundle',
3747
'bzrlib.tests.test_identitymap',
3748
'bzrlib.tests.test_ignores',
3749
'bzrlib.tests.test_index',
3750
'bzrlib.tests.test_import_tariff',
3751
'bzrlib.tests.test_info',
3752
'bzrlib.tests.test_inv',
3753
'bzrlib.tests.test_inventory_delta',
3754
'bzrlib.tests.test_knit',
3755
'bzrlib.tests.test_lazy_import',
3756
'bzrlib.tests.test_lazy_regex',
3757
'bzrlib.tests.test_library_state',
3758
'bzrlib.tests.test_lock',
3759
'bzrlib.tests.test_lockable_files',
3760
'bzrlib.tests.test_lockdir',
3761
'bzrlib.tests.test_log',
3762
'bzrlib.tests.test_lru_cache',
3763
'bzrlib.tests.test_lsprof',
3764
'bzrlib.tests.test_mail_client',
3765
'bzrlib.tests.test_matchers',
3766
'bzrlib.tests.test_memorytree',
3767
'bzrlib.tests.test_merge',
3768
'bzrlib.tests.test_merge3',
3769
'bzrlib.tests.test_merge_core',
3770
'bzrlib.tests.test_merge_directive',
3771
'bzrlib.tests.test_missing',
3772
'bzrlib.tests.test_msgeditor',
3773
'bzrlib.tests.test_multiparent',
3774
'bzrlib.tests.test_mutabletree',
3775
'bzrlib.tests.test_nonascii',
3776
'bzrlib.tests.test_options',
3777
'bzrlib.tests.test_osutils',
3778
'bzrlib.tests.test_osutils_encodings',
3779
'bzrlib.tests.test_pack',
3780
'bzrlib.tests.test_patch',
3781
'bzrlib.tests.test_patches',
3782
'bzrlib.tests.test_permissions',
3783
'bzrlib.tests.test_plugins',
3784
'bzrlib.tests.test_progress',
3785
'bzrlib.tests.test_read_bundle',
3786
'bzrlib.tests.test_reconcile',
3787
'bzrlib.tests.test_reconfigure',
3788
'bzrlib.tests.test_registry',
3789
'bzrlib.tests.test_remote',
3790
'bzrlib.tests.test_rename_map',
3791
'bzrlib.tests.test_repository',
3792
'bzrlib.tests.test_revert',
3793
'bzrlib.tests.test_revision',
3794
'bzrlib.tests.test_revisionspec',
3795
'bzrlib.tests.test_revisiontree',
3796
'bzrlib.tests.test_rio',
3797
'bzrlib.tests.test_rules',
3798
'bzrlib.tests.test_sampler',
3799
'bzrlib.tests.test_script',
3800
'bzrlib.tests.test_selftest',
3801
'bzrlib.tests.test_serializer',
3802
'bzrlib.tests.test_setup',
3803
'bzrlib.tests.test_sftp_transport',
3804
'bzrlib.tests.test_shelf',
3805
'bzrlib.tests.test_shelf_ui',
3806
'bzrlib.tests.test_smart',
3807
'bzrlib.tests.test_smart_add',
3808
'bzrlib.tests.test_smart_request',
3809
'bzrlib.tests.test_smart_transport',
3810
'bzrlib.tests.test_smtp_connection',
3811
'bzrlib.tests.test_source',
3812
'bzrlib.tests.test_ssh_transport',
3813
'bzrlib.tests.test_status',
3814
'bzrlib.tests.test_store',
3815
'bzrlib.tests.test_strace',
3816
'bzrlib.tests.test_subsume',
3817
'bzrlib.tests.test_switch',
3818
'bzrlib.tests.test_symbol_versioning',
3819
'bzrlib.tests.test_tag',
3820
'bzrlib.tests.test_test_server',
3821
'bzrlib.tests.test_testament',
3822
'bzrlib.tests.test_textfile',
3823
'bzrlib.tests.test_textmerge',
3824
'bzrlib.tests.test_timestamp',
3825
'bzrlib.tests.test_trace',
3826
'bzrlib.tests.test_transactions',
3827
'bzrlib.tests.test_transform',
3828
'bzrlib.tests.test_transport',
3829
'bzrlib.tests.test_transport_log',
3830
'bzrlib.tests.test_tree',
3831
'bzrlib.tests.test_treebuilder',
3832
'bzrlib.tests.test_treeshape',
3833
'bzrlib.tests.test_tsort',
3834
'bzrlib.tests.test_tuned_gzip',
3835
'bzrlib.tests.test_ui',
3836
'bzrlib.tests.test_uncommit',
3837
'bzrlib.tests.test_upgrade',
3838
'bzrlib.tests.test_upgrade_stacked',
3839
'bzrlib.tests.test_urlutils',
3840
'bzrlib.tests.test_version',
3841
'bzrlib.tests.test_version_info',
3842
'bzrlib.tests.test_versionedfile',
3843
'bzrlib.tests.test_weave',
3844
'bzrlib.tests.test_whitebox',
3845
'bzrlib.tests.test_win32utils',
3846
'bzrlib.tests.test_workingtree',
3847
'bzrlib.tests.test_workingtree_4',
3848
'bzrlib.tests.test_wsgi',
3849
'bzrlib.tests.test_xml',
3853
def _test_suite_modules_to_doctest():
3854
"""Return the list of modules to doctest."""
3856
# GZ 2009-03-31: No docstrings with -OO so there's nothing to doctest
3860
'bzrlib.branchbuilder',
3861
'bzrlib.decorators',
3864
'bzrlib.iterablefile',
3868
'bzrlib.symbol_versioning',
3870
'bzrlib.tests.fixtures',
3872
'bzrlib.version_info_formats.format_custom',
3055
3876
def test_suite(keep_only=None, starting_with=None):
3056
3877
"""Build and return TestSuite for the whole of bzrlib.
3063
3884
This function can be replaced if you need to change the default test
3064
3885
suite on a global basis, but it is not encouraged.
3068
'bzrlib.tests.blackbox',
3069
'bzrlib.tests.branch_implementations',
3070
'bzrlib.tests.bzrdir_implementations',
3071
'bzrlib.tests.commands',
3072
'bzrlib.tests.interrepository_implementations',
3073
'bzrlib.tests.intertree_implementations',
3074
'bzrlib.tests.inventory_implementations',
3075
'bzrlib.tests.per_interbranch',
3076
'bzrlib.tests.per_lock',
3077
'bzrlib.tests.per_repository',
3078
'bzrlib.tests.per_repository_chk',
3079
'bzrlib.tests.per_repository_reference',
3080
'bzrlib.tests.test__chk_map',
3081
'bzrlib.tests.test__dirstate_helpers',
3082
'bzrlib.tests.test__groupcompress',
3083
'bzrlib.tests.test__walkdirs_win32',
3084
'bzrlib.tests.test_ancestry',
3085
'bzrlib.tests.test_annotate',
3086
'bzrlib.tests.test_api',
3087
'bzrlib.tests.test_atomicfile',
3088
'bzrlib.tests.test_bad_files',
3089
'bzrlib.tests.test_bisect_multi',
3090
'bzrlib.tests.test_branch',
3091
'bzrlib.tests.test_branchbuilder',
3092
'bzrlib.tests.test_btree_index',
3093
'bzrlib.tests.test_bugtracker',
3094
'bzrlib.tests.test_bundle',
3095
'bzrlib.tests.test_bzrdir',
3096
'bzrlib.tests.test__chunks_to_lines',
3097
'bzrlib.tests.test_cache_utf8',
3098
'bzrlib.tests.test_chk_map',
3099
'bzrlib.tests.test_chunk_writer',
3100
'bzrlib.tests.test_clean_tree',
3101
'bzrlib.tests.test_commands',
3102
'bzrlib.tests.test_commit',
3103
'bzrlib.tests.test_commit_merge',
3104
'bzrlib.tests.test_config',
3105
'bzrlib.tests.test_conflicts',
3106
'bzrlib.tests.test_counted_lock',
3107
'bzrlib.tests.test_decorators',
3108
'bzrlib.tests.test_delta',
3109
'bzrlib.tests.test_debug',
3110
'bzrlib.tests.test_deprecated_graph',
3111
'bzrlib.tests.test_diff',
3112
'bzrlib.tests.test_directory_service',
3113
'bzrlib.tests.test_dirstate',
3114
'bzrlib.tests.test_email_message',
3115
'bzrlib.tests.test_errors',
3116
'bzrlib.tests.test_export',
3117
'bzrlib.tests.test_extract',
3118
'bzrlib.tests.test_fetch',
3119
'bzrlib.tests.test_fifo_cache',
3120
'bzrlib.tests.test_filters',
3121
'bzrlib.tests.test_ftp_transport',
3122
'bzrlib.tests.test_foreign',
3123
'bzrlib.tests.test_generate_docs',
3124
'bzrlib.tests.test_generate_ids',
3125
'bzrlib.tests.test_globbing',
3126
'bzrlib.tests.test_gpg',
3127
'bzrlib.tests.test_graph',
3128
'bzrlib.tests.test_groupcompress',
3129
'bzrlib.tests.test_hashcache',
3130
'bzrlib.tests.test_help',
3131
'bzrlib.tests.test_hooks',
3132
'bzrlib.tests.test_http',
3133
'bzrlib.tests.test_http_implementations',
3134
'bzrlib.tests.test_http_response',
3135
'bzrlib.tests.test_https_ca_bundle',
3136
'bzrlib.tests.test_identitymap',
3137
'bzrlib.tests.test_ignores',
3138
'bzrlib.tests.test_index',
3139
'bzrlib.tests.test_info',
3140
'bzrlib.tests.test_inv',
3141
'bzrlib.tests.test_knit',
3142
'bzrlib.tests.test_lazy_import',
3143
'bzrlib.tests.test_lazy_regex',
3144
'bzrlib.tests.test_lockable_files',
3145
'bzrlib.tests.test_lockdir',
3146
'bzrlib.tests.test_log',
3147
'bzrlib.tests.test_lru_cache',
3148
'bzrlib.tests.test_lsprof',
3149
'bzrlib.tests.test_mail_client',
3150
'bzrlib.tests.test_memorytree',
3151
'bzrlib.tests.test_merge',
3152
'bzrlib.tests.test_merge3',
3153
'bzrlib.tests.test_merge_core',
3154
'bzrlib.tests.test_merge_directive',
3155
'bzrlib.tests.test_missing',
3156
'bzrlib.tests.test_msgeditor',
3157
'bzrlib.tests.test_multiparent',
3158
'bzrlib.tests.test_mutabletree',
3159
'bzrlib.tests.test_nonascii',
3160
'bzrlib.tests.test_options',
3161
'bzrlib.tests.test_osutils',
3162
'bzrlib.tests.test_osutils_encodings',
3163
'bzrlib.tests.test_pack',
3164
'bzrlib.tests.test_pack_repository',
3165
'bzrlib.tests.test_patch',
3166
'bzrlib.tests.test_patches',
3167
'bzrlib.tests.test_permissions',
3168
'bzrlib.tests.test_plugins',
3169
'bzrlib.tests.test_progress',
3170
'bzrlib.tests.test_read_bundle',
3171
'bzrlib.tests.test_reconcile',
3172
'bzrlib.tests.test_reconfigure',
3173
'bzrlib.tests.test_registry',
3174
'bzrlib.tests.test_remote',
3175
'bzrlib.tests.test_rename_map',
3176
'bzrlib.tests.test_repository',
3177
'bzrlib.tests.test_revert',
3178
'bzrlib.tests.test_revision',
3179
'bzrlib.tests.test_revisionspec',
3180
'bzrlib.tests.test_revisiontree',
3181
'bzrlib.tests.test_rio',
3182
'bzrlib.tests.test_rules',
3183
'bzrlib.tests.test_sampler',
3184
'bzrlib.tests.test_selftest',
3185
'bzrlib.tests.test_setup',
3186
'bzrlib.tests.test_sftp_transport',
3187
'bzrlib.tests.test_shelf',
3188
'bzrlib.tests.test_shelf_ui',
3189
'bzrlib.tests.test_smart',
3190
'bzrlib.tests.test_smart_add',
3191
'bzrlib.tests.test_smart_request',
3192
'bzrlib.tests.test_smart_transport',
3193
'bzrlib.tests.test_smtp_connection',
3194
'bzrlib.tests.test_source',
3195
'bzrlib.tests.test_ssh_transport',
3196
'bzrlib.tests.test_status',
3197
'bzrlib.tests.test_store',
3198
'bzrlib.tests.test_strace',
3199
'bzrlib.tests.test_subsume',
3200
'bzrlib.tests.test_switch',
3201
'bzrlib.tests.test_symbol_versioning',
3202
'bzrlib.tests.test_tag',
3203
'bzrlib.tests.test_testament',
3204
'bzrlib.tests.test_textfile',
3205
'bzrlib.tests.test_textmerge',
3206
'bzrlib.tests.test_timestamp',
3207
'bzrlib.tests.test_trace',
3208
'bzrlib.tests.test_transactions',
3209
'bzrlib.tests.test_transform',
3210
'bzrlib.tests.test_transport',
3211
'bzrlib.tests.test_transport_implementations',
3212
'bzrlib.tests.test_transport_log',
3213
'bzrlib.tests.test_tree',
3214
'bzrlib.tests.test_treebuilder',
3215
'bzrlib.tests.test_tsort',
3216
'bzrlib.tests.test_tuned_gzip',
3217
'bzrlib.tests.test_ui',
3218
'bzrlib.tests.test_uncommit',
3219
'bzrlib.tests.test_upgrade',
3220
'bzrlib.tests.test_upgrade_stacked',
3221
'bzrlib.tests.test_urlutils',
3222
'bzrlib.tests.test_version',
3223
'bzrlib.tests.test_version_info',
3224
'bzrlib.tests.test_versionedfile',
3225
'bzrlib.tests.test_weave',
3226
'bzrlib.tests.test_whitebox',
3227
'bzrlib.tests.test_win32utils',
3228
'bzrlib.tests.test_workingtree',
3229
'bzrlib.tests.test_workingtree_4',
3230
'bzrlib.tests.test_wsgi',
3231
'bzrlib.tests.test_xml',
3232
'bzrlib.tests.tree_implementations',
3233
'bzrlib.tests.workingtree_implementations',
3234
'bzrlib.util.tests.test_bencode',
3237
3888
loader = TestUtil.TestLoader()
3890
if keep_only is not None:
3891
id_filter = TestIdList(keep_only)
3239
3892
if starting_with:
3240
starting_with = [test_prefix_alias_registry.resolve_alias(start)
3241
for start in starting_with]
3242
3893
# We take precedence over keep_only because *at loading time* using
3243
3894
# both options means we will load less tests for the same final result.
3244
3895
def interesting_module(name):
3549
4226
UnicodeFilenameFeature = _UnicodeFilenameFeature()
4229
class _CompatabilityThunkFeature(Feature):
4230
"""This feature is just a thunk to another feature.
4232
It issues a deprecation warning if it is accessed, to let you know that you
4233
should really use a different feature.
4236
def __init__(self, dep_version, module, name,
4237
replacement_name, replacement_module=None):
4238
super(_CompatabilityThunkFeature, self).__init__()
4239
self._module = module
4240
if replacement_module is None:
4241
replacement_module = module
4242
self._replacement_module = replacement_module
4244
self._replacement_name = replacement_name
4245
self._dep_version = dep_version
4246
self._feature = None
4249
if self._feature is None:
4250
depr_msg = self._dep_version % ('%s.%s'
4251
% (self._module, self._name))
4252
use_msg = ' Use %s.%s instead.' % (self._replacement_module,
4253
self._replacement_name)
4254
symbol_versioning.warn(depr_msg + use_msg, DeprecationWarning)
4255
# Import the new feature and use it as a replacement for the
4257
mod = __import__(self._replacement_module, {}, {},
4258
[self._replacement_name])
4259
self._feature = getattr(mod, self._replacement_name)
4263
return self._feature._probe()
4266
class ModuleAvailableFeature(Feature):
4267
"""This is a feature than describes a module we want to be available.
4269
Declare the name of the module in __init__(), and then after probing, the
4270
module will be available as 'self.module'.
4272
:ivar module: The module if it is available, else None.
4275
def __init__(self, module_name):
4276
super(ModuleAvailableFeature, self).__init__()
4277
self.module_name = module_name
4281
self._module = __import__(self.module_name, {}, {}, [''])
4288
if self.available(): # Make sure the probe has been done
4292
def feature_name(self):
4293
return self.module_name
4296
# This is kept here for compatibility, it is recommended to use
4297
# 'bzrlib.tests.feature.paramiko' instead
4298
ParamikoFeature = _CompatabilityThunkFeature(
4299
deprecated_in((2,1,0)),
4300
'bzrlib.tests.features', 'ParamikoFeature', 'paramiko')
3552
4303
def probe_unicode_in_user_encoding():
3553
4304
"""Try to encode several unicode strings to use in unicode-aware tests.
3554
4305
Return first successfull match.