170
191
self._overall_start_time = time.time()
171
192
self._strict = strict
194
def stopTestRun(self):
197
stopTime = time.time()
198
timeTaken = stopTime - self.startTime
200
self.stream.writeln(self.separator2)
201
self.stream.writeln("%s %d test%s in %.3fs" % (actionTaken,
202
run, run != 1 and "s" or "", timeTaken))
203
self.stream.writeln()
204
if not self.wasSuccessful():
205
self.stream.write("FAILED (")
206
failed, errored = map(len, (self.failures, self.errors))
208
self.stream.write("failures=%d" % failed)
210
if failed: self.stream.write(", ")
211
self.stream.write("errors=%d" % errored)
212
if self.known_failure_count:
213
if failed or errored: self.stream.write(", ")
214
self.stream.write("known_failure_count=%d" %
215
self.known_failure_count)
216
self.stream.writeln(")")
218
if self.known_failure_count:
219
self.stream.writeln("OK (known_failures=%d)" %
220
self.known_failure_count)
222
self.stream.writeln("OK")
223
if self.skip_count > 0:
224
skipped = self.skip_count
225
self.stream.writeln('%d test%s skipped' %
226
(skipped, skipped != 1 and "s" or ""))
228
for feature, count in sorted(self.unsupported.items()):
229
self.stream.writeln("Missing feature '%s' skipped %d tests." %
175
232
ok = self.wasStrictlySuccessful()
177
234
ok = self.wasSuccessful()
179
self.stream.write('tests passed\n')
181
self.stream.write('tests failed\n')
182
235
if TestCase._first_thread_leaker_id:
183
236
self.stream.write(
184
237
'%s is leaking threads among %d leaking tests.\n' % (
185
238
TestCase._first_thread_leaker_id,
186
239
TestCase._leaking_threads_tests))
188
def _extractBenchmarkTime(self, testCase):
240
# We don't report the main thread as an active one.
242
'%d non-main threads were left active in the end.\n'
243
% (TestCase._active_threads - 1))
245
def getDescription(self, test):
248
def _extractBenchmarkTime(self, testCase, details=None):
189
249
"""Add a benchmark time for the current test case."""
250
if details and 'benchtime' in details:
251
return float(''.join(details['benchtime'].iter_bytes()))
190
252
return getattr(testCase, "_benchtime", None)
192
254
def _elapsedTestTimeString(self):
547
593
bench_history=None,
595
result_decorators=None,
597
"""Create a TextTestRunner.
599
:param result_decorators: An optional list of decorators to apply
600
to the result object being used by the runner. Decorators are
601
applied left to right - the first element in the list is the
604
# stream may know claim to know to write unicode strings, but in older
605
# pythons this goes sufficiently wrong that it is a bad idea. (
606
# specifically a built in file with encoding 'UTF-8' will still try
607
# to encode using ascii.
608
new_encoding = osutils.get_terminal_encoding()
609
codec = codecs.lookup(new_encoding)
610
if type(codec) is tuple:
614
encode = codec.encode
615
stream = osutils.UnicodeOrBytesToBytesWriter(encode, stream)
616
stream.encoding = new_encoding
551
617
self.stream = unittest._WritelnDecorator(stream)
552
618
self.descriptions = descriptions
553
619
self.verbosity = verbosity
554
620
self._bench_history = bench_history
555
self.list_only = list_only
556
621
self._strict = strict
622
self._result_decorators = result_decorators or []
558
624
def run(self, test):
559
625
"Run the given test case or test suite."
560
startTime = time.time()
561
626
if self.verbosity == 1:
562
627
result_class = TextTestResult
563
628
elif self.verbosity >= 2:
564
629
result_class = VerboseTestResult
565
result = result_class(self.stream,
630
original_result = result_class(self.stream,
566
631
self.descriptions,
568
633
bench_history=self._bench_history,
569
num_tests=test.countTestCases(),
570
634
strict=self._strict,
572
result.stop_early = self.stop_on_failure
573
result.report_starting()
575
if self.verbosity >= 2:
576
self.stream.writeln("Listing tests only ...\n")
578
for t in iter_suite_tests(test):
579
self.stream.writeln("%s" % (t.id()))
588
if isinstance(test, testtools.ConcurrentTestSuite):
589
# We need to catch bzr specific behaviors
590
test.run(BZRTransformingResult(result))
593
run = result.testsRun
595
stopTime = time.time()
596
timeTaken = stopTime - startTime
598
self.stream.writeln(result.separator2)
599
self.stream.writeln("%s %d test%s in %.3fs" % (actionTaken,
600
run, run != 1 and "s" or "", timeTaken))
601
self.stream.writeln()
602
if not result.wasSuccessful():
603
self.stream.write("FAILED (")
604
failed, errored = map(len, (result.failures, result.errors))
606
self.stream.write("failures=%d" % failed)
608
if failed: self.stream.write(", ")
609
self.stream.write("errors=%d" % errored)
610
if result.known_failure_count:
611
if failed or errored: self.stream.write(", ")
612
self.stream.write("known_failure_count=%d" %
613
result.known_failure_count)
614
self.stream.writeln(")")
616
if result.known_failure_count:
617
self.stream.writeln("OK (known_failures=%d)" %
618
result.known_failure_count)
620
self.stream.writeln("OK")
621
if result.skip_count > 0:
622
skipped = result.skip_count
623
self.stream.writeln('%d test%s skipped' %
624
(skipped, skipped != 1 and "s" or ""))
625
if result.unsupported:
626
for feature, count in sorted(result.unsupported.items()):
627
self.stream.writeln("Missing feature '%s' skipped %d tests." %
636
# Signal to result objects that look at stop early policy to stop,
637
original_result.stop_early = self.stop_on_failure
638
result = original_result
639
for decorator in self._result_decorators:
640
result = decorator(result)
641
result.stop_early = self.stop_on_failure
642
result.startTestRun()
647
# higher level code uses our extended protocol to determine
648
# what exit code to give.
649
return original_result
633
652
def iter_suite_tests(suite):
905
936
def _lock_broken(self, result):
906
937
self._lock_actions.append(('broken', result))
939
def permit_dir(self, name):
940
"""Permit a directory to be used by this test. See permit_url."""
941
name_transport = get_transport(name)
942
self.permit_url(name)
943
self.permit_url(name_transport.base)
945
def permit_url(self, url):
946
"""Declare that url is an ok url to use in this test.
948
Do this for memory transports, temporary test directory etc.
950
Do not do this for the current working directory, /tmp, or any other
951
preexisting non isolated url.
953
if not url.endswith('/'):
955
self._bzr_selftest_roots.append(url)
957
def permit_source_tree_branch_repo(self):
958
"""Permit the source tree bzr is running from to be opened.
960
Some code such as bzrlib.version attempts to read from the bzr branch
961
that bzr is executing from (if any). This method permits that directory
962
to be used in the test suite.
964
path = self.get_source_path()
965
self.record_directory_isolation()
968
workingtree.WorkingTree.open(path)
969
except (errors.NotBranchError, errors.NoWorkingTree):
972
self.enable_directory_isolation()
974
def _preopen_isolate_transport(self, transport):
975
"""Check that all transport openings are done in the test work area."""
976
while isinstance(transport, pathfilter.PathFilteringTransport):
977
# Unwrap pathfiltered transports
978
transport = transport.server.backing_transport.clone(
979
transport._filter('.'))
981
# ReadonlySmartTCPServer_for_testing decorates the backing transport
982
# urls it is given by prepending readonly+. This is appropriate as the
983
# client shouldn't know that the server is readonly (or not readonly).
984
# We could register all servers twice, with readonly+ prepending, but
985
# that makes for a long list; this is about the same but easier to
987
if url.startswith('readonly+'):
988
url = url[len('readonly+'):]
989
self._preopen_isolate_url(url)
991
def _preopen_isolate_url(self, url):
992
if not self._directory_isolation:
994
if self._directory_isolation == 'record':
995
self._bzr_selftest_roots.append(url)
997
# This prevents all transports, including e.g. sftp ones backed on disk
998
# from working unless they are explicitly granted permission. We then
999
# depend on the code that sets up test transports to check that they are
1000
# appropriately isolated and enable their use by calling
1001
# self.permit_transport()
1002
if not osutils.is_inside_any(self._bzr_selftest_roots, url):
1003
raise errors.BzrError("Attempt to escape test isolation: %r %r"
1004
% (url, self._bzr_selftest_roots))
1006
def record_directory_isolation(self):
1007
"""Gather accessed directories to permit later access.
1009
This is used for tests that access the branch bzr is running from.
1011
self._directory_isolation = "record"
1013
def start_server(self, transport_server, backing_server=None):
1014
"""Start transport_server for this test.
1016
This starts the server, registers a cleanup for it and permits the
1017
server's urls to be used.
1019
if backing_server is None:
1020
transport_server.start_server()
1022
transport_server.start_server(backing_server)
1023
self.addCleanup(transport_server.stop_server)
1024
# Obtain a real transport because if the server supplies a password, it
1025
# will be hidden from the base on the client side.
1026
t = get_transport(transport_server.get_url())
1027
# Some transport servers effectively chroot the backing transport;
1028
# others like SFTPServer don't - users of the transport can walk up the
1029
# transport to read the entire backing transport. This wouldn't matter
1030
# except that the workdir tests are given - and that they expect the
1031
# server's url to point at - is one directory under the safety net. So
1032
# Branch operations into the transport will attempt to walk up one
1033
# directory. Chrooting all servers would avoid this but also mean that
1034
# we wouldn't be testing directly against non-root urls. Alternatively
1035
# getting the test framework to start the server with a backing server
1036
# at the actual safety net directory would work too, but this then
1037
# means that the self.get_url/self.get_transport methods would need
1038
# to transform all their results. On balance its cleaner to handle it
1039
# here, and permit a higher url when we have one of these transports.
1040
if t.base.endswith('/work/'):
1041
# we have safety net/test root/work
1042
t = t.clone('../..')
1043
elif isinstance(transport_server, server.SmartTCPServer_for_testing):
1044
# The smart server adds a path similar to work, which is traversed
1045
# up from by the client. But the server is chrooted - the actual
1046
# backing transport is not escaped from, and VFS requests to the
1047
# root will error (because they try to escape the chroot).
1049
while t2.base != t.base:
1052
self.permit_url(t.base)
1054
def _track_transports(self):
1055
"""Install checks for transport usage."""
1056
# TestCase has no safe place it can write to.
1057
self._bzr_selftest_roots = []
1058
# Currently the easiest way to be sure that nothing is going on is to
1059
# hook into bzr dir opening. This leaves a small window of error for
1060
# transport tests, but they are well known, and we can improve on this
1062
bzrdir.BzrDir.hooks.install_named_hook("pre_open",
1063
self._preopen_isolate_transport, "Check bzr directories are safe.")
908
1065
def _ndiff_strings(self, a, b):
909
1066
"""Return ndiff between two strings containing lines.
1385
1570
def _do_skip(self, result, reason):
1386
1571
addSkip = getattr(result, 'addSkip', None)
1387
1572
if not callable(addSkip):
1388
result.addError(self, sys.exc_info())
1573
result.addSuccess(result)
1390
1575
addSkip(self, reason)
1392
def run(self, result=None):
1393
if result is None: result = self.defaultTestResult()
1394
for feature in getattr(self, '_test_needs_features', []):
1395
if not feature.available():
1396
result.startTest(self)
1397
if getattr(result, 'addNotSupported', None):
1398
result.addNotSupported(self, feature)
1400
result.addSuccess(self)
1401
result.stopTest(self)
1405
result.startTest(self)
1406
absent_attr = object()
1408
method_name = getattr(self, '_testMethodName', absent_attr)
1409
if method_name is absent_attr:
1411
method_name = getattr(self, '_TestCase__testMethodName')
1412
testMethod = getattr(self, method_name)
1416
if not self._bzr_test_setUp_run:
1418
"test setUp did not invoke "
1419
"bzrlib.tests.TestCase's setUp")
1420
except KeyboardInterrupt:
1423
except TestSkipped, e:
1424
self._do_skip(result, e.args[0])
1428
result.addError(self, sys.exc_info())
1436
except self.failureException:
1437
result.addFailure(self, sys.exc_info())
1438
except TestSkipped, e:
1440
reason = "No reason given."
1443
self._do_skip(result, reason)
1444
except KeyboardInterrupt:
1448
result.addError(self, sys.exc_info())
1452
if not self._bzr_test_tearDown_run:
1454
"test tearDown did not invoke "
1455
"bzrlib.tests.TestCase's tearDown")
1456
except KeyboardInterrupt:
1460
result.addError(self, sys.exc_info())
1463
if ok: result.addSuccess(self)
1465
result.stopTest(self)
1467
except TestNotApplicable:
1468
# Not moved from the result [yet].
1471
except KeyboardInterrupt:
1476
for attr_name in self.attrs_to_keep:
1477
if attr_name in self.__dict__:
1478
saved_attrs[attr_name] = self.__dict__[attr_name]
1479
self.__dict__ = saved_attrs
1483
self._log_contents = ''
1484
self._bzr_test_tearDown_run = True
1485
unittest.TestCase.tearDown(self)
1578
def _do_known_failure(self, result, e):
1579
err = sys.exc_info()
1580
addExpectedFailure = getattr(result, 'addExpectedFailure', None)
1581
if addExpectedFailure is not None:
1582
addExpectedFailure(self, err)
1584
result.addSuccess(self)
1587
def _do_not_applicable(self, result, e):
1589
reason = 'No reason given'
1592
addNotApplicable = getattr(result, 'addNotApplicable', None)
1593
if addNotApplicable is not None:
1594
result.addNotApplicable(self, reason)
1596
self._do_skip(result, reason)
1599
def _do_unsupported_or_skip(self, result, e):
1601
addNotSupported = getattr(result, 'addNotSupported', None)
1602
if addNotSupported is not None:
1603
result.addNotSupported(self, reason)
1605
self._do_skip(result, reason)
1487
1607
def time(self, callable, *args, **kwargs):
1488
1608
"""Run callable and accrue the time it takes to the benchmark time.
3098
3290
def addSuccess(self, test):
3099
3291
self.result.addSuccess(test)
3101
def _error_looks_like(self, prefix, err):
3102
"""Deserialize exception and returns the stringify value."""
3106
if isinstance(exc, subunit.RemoteException):
3107
# stringify the exception gives access to the remote traceback
3108
# We search the last line for 'prefix'
3109
lines = str(exc).split('\n')
3110
while lines and not lines[-1]:
3113
if lines[-1].startswith(prefix):
3114
value = lines[-1][len(prefix):]
3293
def addError(self, test, err):
3294
self.result.addError(test, err)
3296
def addFailure(self, test, err):
3297
self.result.addFailure(test, err)
3298
ForwardingResult = testtools.ExtendedToOriginalDecorator
3301
class ProfileResult(ForwardingResult):
3302
"""Generate profiling data for all activity between start and success.
3304
The profile data is appended to the test's _benchcalls attribute and can
3305
be accessed by the forwarded-to TestResult.
3307
While it might be cleaner do accumulate this in stopTest, addSuccess is
3308
where our existing output support for lsprof is, and this class aims to
3309
fit in with that: while it could be moved it's not necessary to accomplish
3310
test profiling, nor would it be dramatically cleaner.
3313
def startTest(self, test):
3314
self.profiler = bzrlib.lsprof.BzrProfiler()
3315
self.profiler.start()
3316
ForwardingResult.startTest(self, test)
3318
def addSuccess(self, test):
3319
stats = self.profiler.stop()
3321
calls = test._benchcalls
3322
except AttributeError:
3323
test._benchcalls = []
3324
calls = test._benchcalls
3325
calls.append(((test.id(), "", ""), stats))
3326
ForwardingResult.addSuccess(self, test)
3328
def stopTest(self, test):
3329
ForwardingResult.stopTest(self, test)
3330
self.profiler = None
3118
3333
# Controlled by "bzr selftest -E=..." option
3334
# Currently supported:
3335
# -Eallow_debug Will no longer clear debug.debug_flags() so it
3336
# preserves any flags supplied at the command line.
3337
# -Edisable_lock_checks Turns errors in mismatched locks into simple prints
3338
# rather than failing tests. And no longer raise
3339
# LockContention when fctnl locks are not being used
3340
# with proper exclusion rules.
3119
3341
selftest_debug_flags = set()
3333
3570
test_prefix_alias_registry.register('bp', 'bzrlib.plugins')
3573
def _test_suite_testmod_names():
3574
"""Return the standard list of test module names to test."""
3577
'bzrlib.tests.blackbox',
3578
'bzrlib.tests.commands',
3579
'bzrlib.tests.per_branch',
3580
'bzrlib.tests.per_bzrdir',
3581
'bzrlib.tests.per_foreign_vcs',
3582
'bzrlib.tests.per_interrepository',
3583
'bzrlib.tests.per_intertree',
3584
'bzrlib.tests.per_inventory',
3585
'bzrlib.tests.per_interbranch',
3586
'bzrlib.tests.per_lock',
3587
'bzrlib.tests.per_merger',
3588
'bzrlib.tests.per_transport',
3589
'bzrlib.tests.per_tree',
3590
'bzrlib.tests.per_pack_repository',
3591
'bzrlib.tests.per_repository',
3592
'bzrlib.tests.per_repository_chk',
3593
'bzrlib.tests.per_repository_reference',
3594
'bzrlib.tests.per_uifactory',
3595
'bzrlib.tests.per_versionedfile',
3596
'bzrlib.tests.per_workingtree',
3597
'bzrlib.tests.test__annotator',
3598
'bzrlib.tests.test__bencode',
3599
'bzrlib.tests.test__chk_map',
3600
'bzrlib.tests.test__dirstate_helpers',
3601
'bzrlib.tests.test__groupcompress',
3602
'bzrlib.tests.test__known_graph',
3603
'bzrlib.tests.test__rio',
3604
'bzrlib.tests.test__simple_set',
3605
'bzrlib.tests.test__static_tuple',
3606
'bzrlib.tests.test__walkdirs_win32',
3607
'bzrlib.tests.test_ancestry',
3608
'bzrlib.tests.test_annotate',
3609
'bzrlib.tests.test_api',
3610
'bzrlib.tests.test_atomicfile',
3611
'bzrlib.tests.test_bad_files',
3612
'bzrlib.tests.test_bisect_multi',
3613
'bzrlib.tests.test_branch',
3614
'bzrlib.tests.test_branchbuilder',
3615
'bzrlib.tests.test_btree_index',
3616
'bzrlib.tests.test_bugtracker',
3617
'bzrlib.tests.test_bundle',
3618
'bzrlib.tests.test_bzrdir',
3619
'bzrlib.tests.test__chunks_to_lines',
3620
'bzrlib.tests.test_cache_utf8',
3621
'bzrlib.tests.test_chk_map',
3622
'bzrlib.tests.test_chk_serializer',
3623
'bzrlib.tests.test_chunk_writer',
3624
'bzrlib.tests.test_clean_tree',
3625
'bzrlib.tests.test_cleanup',
3626
'bzrlib.tests.test_commands',
3627
'bzrlib.tests.test_commit',
3628
'bzrlib.tests.test_commit_merge',
3629
'bzrlib.tests.test_config',
3630
'bzrlib.tests.test_conflicts',
3631
'bzrlib.tests.test_counted_lock',
3632
'bzrlib.tests.test_crash',
3633
'bzrlib.tests.test_decorators',
3634
'bzrlib.tests.test_delta',
3635
'bzrlib.tests.test_debug',
3636
'bzrlib.tests.test_deprecated_graph',
3637
'bzrlib.tests.test_diff',
3638
'bzrlib.tests.test_directory_service',
3639
'bzrlib.tests.test_dirstate',
3640
'bzrlib.tests.test_email_message',
3641
'bzrlib.tests.test_eol_filters',
3642
'bzrlib.tests.test_errors',
3643
'bzrlib.tests.test_export',
3644
'bzrlib.tests.test_extract',
3645
'bzrlib.tests.test_fetch',
3646
'bzrlib.tests.test_fifo_cache',
3647
'bzrlib.tests.test_filters',
3648
'bzrlib.tests.test_ftp_transport',
3649
'bzrlib.tests.test_foreign',
3650
'bzrlib.tests.test_generate_docs',
3651
'bzrlib.tests.test_generate_ids',
3652
'bzrlib.tests.test_globbing',
3653
'bzrlib.tests.test_gpg',
3654
'bzrlib.tests.test_graph',
3655
'bzrlib.tests.test_groupcompress',
3656
'bzrlib.tests.test_hashcache',
3657
'bzrlib.tests.test_help',
3658
'bzrlib.tests.test_hooks',
3659
'bzrlib.tests.test_http',
3660
'bzrlib.tests.test_http_response',
3661
'bzrlib.tests.test_https_ca_bundle',
3662
'bzrlib.tests.test_identitymap',
3663
'bzrlib.tests.test_ignores',
3664
'bzrlib.tests.test_index',
3665
'bzrlib.tests.test_import_tariff',
3666
'bzrlib.tests.test_info',
3667
'bzrlib.tests.test_inv',
3668
'bzrlib.tests.test_inventory_delta',
3669
'bzrlib.tests.test_knit',
3670
'bzrlib.tests.test_lazy_import',
3671
'bzrlib.tests.test_lazy_regex',
3672
'bzrlib.tests.test_lock',
3673
'bzrlib.tests.test_lockable_files',
3674
'bzrlib.tests.test_lockdir',
3675
'bzrlib.tests.test_log',
3676
'bzrlib.tests.test_lru_cache',
3677
'bzrlib.tests.test_lsprof',
3678
'bzrlib.tests.test_mail_client',
3679
'bzrlib.tests.test_memorytree',
3680
'bzrlib.tests.test_merge',
3681
'bzrlib.tests.test_merge3',
3682
'bzrlib.tests.test_merge_core',
3683
'bzrlib.tests.test_merge_directive',
3684
'bzrlib.tests.test_missing',
3685
'bzrlib.tests.test_msgeditor',
3686
'bzrlib.tests.test_multiparent',
3687
'bzrlib.tests.test_mutabletree',
3688
'bzrlib.tests.test_nonascii',
3689
'bzrlib.tests.test_options',
3690
'bzrlib.tests.test_osutils',
3691
'bzrlib.tests.test_osutils_encodings',
3692
'bzrlib.tests.test_pack',
3693
'bzrlib.tests.test_patch',
3694
'bzrlib.tests.test_patches',
3695
'bzrlib.tests.test_permissions',
3696
'bzrlib.tests.test_plugins',
3697
'bzrlib.tests.test_progress',
3698
'bzrlib.tests.test_read_bundle',
3699
'bzrlib.tests.test_reconcile',
3700
'bzrlib.tests.test_reconfigure',
3701
'bzrlib.tests.test_registry',
3702
'bzrlib.tests.test_remote',
3703
'bzrlib.tests.test_rename_map',
3704
'bzrlib.tests.test_repository',
3705
'bzrlib.tests.test_revert',
3706
'bzrlib.tests.test_revision',
3707
'bzrlib.tests.test_revisionspec',
3708
'bzrlib.tests.test_revisiontree',
3709
'bzrlib.tests.test_rio',
3710
'bzrlib.tests.test_rules',
3711
'bzrlib.tests.test_sampler',
3712
'bzrlib.tests.test_script',
3713
'bzrlib.tests.test_selftest',
3714
'bzrlib.tests.test_serializer',
3715
'bzrlib.tests.test_setup',
3716
'bzrlib.tests.test_sftp_transport',
3717
'bzrlib.tests.test_shelf',
3718
'bzrlib.tests.test_shelf_ui',
3719
'bzrlib.tests.test_smart',
3720
'bzrlib.tests.test_smart_add',
3721
'bzrlib.tests.test_smart_request',
3722
'bzrlib.tests.test_smart_transport',
3723
'bzrlib.tests.test_smtp_connection',
3724
'bzrlib.tests.test_source',
3725
'bzrlib.tests.test_ssh_transport',
3726
'bzrlib.tests.test_status',
3727
'bzrlib.tests.test_store',
3728
'bzrlib.tests.test_strace',
3729
'bzrlib.tests.test_subsume',
3730
'bzrlib.tests.test_switch',
3731
'bzrlib.tests.test_symbol_versioning',
3732
'bzrlib.tests.test_tag',
3733
'bzrlib.tests.test_testament',
3734
'bzrlib.tests.test_textfile',
3735
'bzrlib.tests.test_textmerge',
3736
'bzrlib.tests.test_timestamp',
3737
'bzrlib.tests.test_trace',
3738
'bzrlib.tests.test_transactions',
3739
'bzrlib.tests.test_transform',
3740
'bzrlib.tests.test_transport',
3741
'bzrlib.tests.test_transport_log',
3742
'bzrlib.tests.test_tree',
3743
'bzrlib.tests.test_treebuilder',
3744
'bzrlib.tests.test_tsort',
3745
'bzrlib.tests.test_tuned_gzip',
3746
'bzrlib.tests.test_ui',
3747
'bzrlib.tests.test_uncommit',
3748
'bzrlib.tests.test_upgrade',
3749
'bzrlib.tests.test_upgrade_stacked',
3750
'bzrlib.tests.test_urlutils',
3751
'bzrlib.tests.test_version',
3752
'bzrlib.tests.test_version_info',
3753
'bzrlib.tests.test_weave',
3754
'bzrlib.tests.test_whitebox',
3755
'bzrlib.tests.test_win32utils',
3756
'bzrlib.tests.test_workingtree',
3757
'bzrlib.tests.test_workingtree_4',
3758
'bzrlib.tests.test_wsgi',
3759
'bzrlib.tests.test_xml',
3763
def _test_suite_modules_to_doctest():
3764
"""Return the list of modules to doctest."""
3767
'bzrlib.branchbuilder',
3768
'bzrlib.decorators',
3771
'bzrlib.iterablefile',
3775
'bzrlib.symbol_versioning',
3778
'bzrlib.version_info_formats.format_custom',
3336
3782
def test_suite(keep_only=None, starting_with=None):
3337
3783
"""Build and return TestSuite for the whole of bzrlib.
3344
3790
This function can be replaced if you need to change the default test
3345
3791
suite on a global basis, but it is not encouraged.
3349
'bzrlib.tests.blackbox',
3350
'bzrlib.tests.commands',
3351
'bzrlib.tests.per_branch',
3352
'bzrlib.tests.per_bzrdir',
3353
'bzrlib.tests.per_interrepository',
3354
'bzrlib.tests.per_intertree',
3355
'bzrlib.tests.per_inventory',
3356
'bzrlib.tests.per_interbranch',
3357
'bzrlib.tests.per_lock',
3358
'bzrlib.tests.per_transport',
3359
'bzrlib.tests.per_tree',
3360
'bzrlib.tests.per_repository',
3361
'bzrlib.tests.per_repository_chk',
3362
'bzrlib.tests.per_repository_reference',
3363
'bzrlib.tests.per_workingtree',
3364
'bzrlib.tests.test__annotator',
3365
'bzrlib.tests.test__chk_map',
3366
'bzrlib.tests.test__dirstate_helpers',
3367
'bzrlib.tests.test__groupcompress',
3368
'bzrlib.tests.test__known_graph',
3369
'bzrlib.tests.test__rio',
3370
'bzrlib.tests.test__walkdirs_win32',
3371
'bzrlib.tests.test_ancestry',
3372
'bzrlib.tests.test_annotate',
3373
'bzrlib.tests.test_api',
3374
'bzrlib.tests.test_atomicfile',
3375
'bzrlib.tests.test_bad_files',
3376
'bzrlib.tests.test_bencode',
3377
'bzrlib.tests.test_bisect_multi',
3378
'bzrlib.tests.test_branch',
3379
'bzrlib.tests.test_branchbuilder',
3380
'bzrlib.tests.test_btree_index',
3381
'bzrlib.tests.test_bugtracker',
3382
'bzrlib.tests.test_bundle',
3383
'bzrlib.tests.test_bzrdir',
3384
'bzrlib.tests.test__chunks_to_lines',
3385
'bzrlib.tests.test_cache_utf8',
3386
'bzrlib.tests.test_chk_map',
3387
'bzrlib.tests.test_chk_serializer',
3388
'bzrlib.tests.test_chunk_writer',
3389
'bzrlib.tests.test_clean_tree',
3390
'bzrlib.tests.test_commands',
3391
'bzrlib.tests.test_commit',
3392
'bzrlib.tests.test_commit_merge',
3393
'bzrlib.tests.test_config',
3394
'bzrlib.tests.test_conflicts',
3395
'bzrlib.tests.test_counted_lock',
3396
'bzrlib.tests.test_decorators',
3397
'bzrlib.tests.test_delta',
3398
'bzrlib.tests.test_debug',
3399
'bzrlib.tests.test_deprecated_graph',
3400
'bzrlib.tests.test_diff',
3401
'bzrlib.tests.test_directory_service',
3402
'bzrlib.tests.test_dirstate',
3403
'bzrlib.tests.test_email_message',
3404
'bzrlib.tests.test_eol_filters',
3405
'bzrlib.tests.test_errors',
3406
'bzrlib.tests.test_export',
3407
'bzrlib.tests.test_extract',
3408
'bzrlib.tests.test_fetch',
3409
'bzrlib.tests.test_fifo_cache',
3410
'bzrlib.tests.test_filters',
3411
'bzrlib.tests.test_ftp_transport',
3412
'bzrlib.tests.test_foreign',
3413
'bzrlib.tests.test_generate_docs',
3414
'bzrlib.tests.test_generate_ids',
3415
'bzrlib.tests.test_globbing',
3416
'bzrlib.tests.test_gpg',
3417
'bzrlib.tests.test_graph',
3418
'bzrlib.tests.test_groupcompress',
3419
'bzrlib.tests.test_hashcache',
3420
'bzrlib.tests.test_help',
3421
'bzrlib.tests.test_hooks',
3422
'bzrlib.tests.test_http',
3423
'bzrlib.tests.test_http_response',
3424
'bzrlib.tests.test_https_ca_bundle',
3425
'bzrlib.tests.test_identitymap',
3426
'bzrlib.tests.test_ignores',
3427
'bzrlib.tests.test_index',
3428
'bzrlib.tests.test_info',
3429
'bzrlib.tests.test_inv',
3430
'bzrlib.tests.test_inventory_delta',
3431
'bzrlib.tests.test_knit',
3432
'bzrlib.tests.test_lazy_import',
3433
'bzrlib.tests.test_lazy_regex',
3434
'bzrlib.tests.test_lockable_files',
3435
'bzrlib.tests.test_lockdir',
3436
'bzrlib.tests.test_log',
3437
'bzrlib.tests.test_lru_cache',
3438
'bzrlib.tests.test_lsprof',
3439
'bzrlib.tests.test_mail_client',
3440
'bzrlib.tests.test_memorytree',
3441
'bzrlib.tests.test_merge',
3442
'bzrlib.tests.test_merge3',
3443
'bzrlib.tests.test_merge_core',
3444
'bzrlib.tests.test_merge_directive',
3445
'bzrlib.tests.test_missing',
3446
'bzrlib.tests.test_msgeditor',
3447
'bzrlib.tests.test_multiparent',
3448
'bzrlib.tests.test_mutabletree',
3449
'bzrlib.tests.test_nonascii',
3450
'bzrlib.tests.test_options',
3451
'bzrlib.tests.test_osutils',
3452
'bzrlib.tests.test_osutils_encodings',
3453
'bzrlib.tests.test_pack',
3454
'bzrlib.tests.test_pack_repository',
3455
'bzrlib.tests.test_patch',
3456
'bzrlib.tests.test_patches',
3457
'bzrlib.tests.test_permissions',
3458
'bzrlib.tests.test_plugins',
3459
'bzrlib.tests.test_progress',
3460
'bzrlib.tests.test_read_bundle',
3461
'bzrlib.tests.test_reconcile',
3462
'bzrlib.tests.test_reconfigure',
3463
'bzrlib.tests.test_registry',
3464
'bzrlib.tests.test_remote',
3465
'bzrlib.tests.test_rename_map',
3466
'bzrlib.tests.test_repository',
3467
'bzrlib.tests.test_revert',
3468
'bzrlib.tests.test_revision',
3469
'bzrlib.tests.test_revisionspec',
3470
'bzrlib.tests.test_revisiontree',
3471
'bzrlib.tests.test_rio',
3472
'bzrlib.tests.test_rules',
3473
'bzrlib.tests.test_sampler',
3474
'bzrlib.tests.test_selftest',
3475
'bzrlib.tests.test_serializer',
3476
'bzrlib.tests.test_setup',
3477
'bzrlib.tests.test_sftp_transport',
3478
'bzrlib.tests.test_shelf',
3479
'bzrlib.tests.test_shelf_ui',
3480
'bzrlib.tests.test_smart',
3481
'bzrlib.tests.test_smart_add',
3482
'bzrlib.tests.test_smart_request',
3483
'bzrlib.tests.test_smart_transport',
3484
'bzrlib.tests.test_smtp_connection',
3485
'bzrlib.tests.test_source',
3486
'bzrlib.tests.test_ssh_transport',
3487
'bzrlib.tests.test_status',
3488
'bzrlib.tests.test_store',
3489
'bzrlib.tests.test_strace',
3490
'bzrlib.tests.test_subsume',
3491
'bzrlib.tests.test_switch',
3492
'bzrlib.tests.test_symbol_versioning',
3493
'bzrlib.tests.test_tag',
3494
'bzrlib.tests.test_testament',
3495
'bzrlib.tests.test_textfile',
3496
'bzrlib.tests.test_textmerge',
3497
'bzrlib.tests.test_timestamp',
3498
'bzrlib.tests.test_trace',
3499
'bzrlib.tests.test_transactions',
3500
'bzrlib.tests.test_transform',
3501
'bzrlib.tests.test_transport',
3502
'bzrlib.tests.test_transport_log',
3503
'bzrlib.tests.test_tree',
3504
'bzrlib.tests.test_treebuilder',
3505
'bzrlib.tests.test_tsort',
3506
'bzrlib.tests.test_tuned_gzip',
3507
'bzrlib.tests.test_ui',
3508
'bzrlib.tests.test_uncommit',
3509
'bzrlib.tests.test_upgrade',
3510
'bzrlib.tests.test_upgrade_stacked',
3511
'bzrlib.tests.test_urlutils',
3512
'bzrlib.tests.test_version',
3513
'bzrlib.tests.test_version_info',
3514
'bzrlib.tests.test_versionedfile',
3515
'bzrlib.tests.test_weave',
3516
'bzrlib.tests.test_whitebox',
3517
'bzrlib.tests.test_win32utils',
3518
'bzrlib.tests.test_workingtree',
3519
'bzrlib.tests.test_workingtree_4',
3520
'bzrlib.tests.test_wsgi',
3521
'bzrlib.tests.test_xml',
3524
3794
loader = TestUtil.TestLoader()
3526
3796
if keep_only is not None:
3527
3797
id_filter = TestIdList(keep_only)
3528
3798
if starting_with:
3529
starting_with = [test_prefix_alias_registry.resolve_alias(start)
3530
for start in starting_with]
3531
3799
# We take precedence over keep_only because *at loading time* using
3532
3800
# both options means we will load less tests for the same final result.
3533
3801
def interesting_module(name):
3838
4129
UnicodeFilenameFeature = _UnicodeFilenameFeature()
4132
class _CompatabilityThunkFeature(Feature):
4133
"""This feature is just a thunk to another feature.
4135
It issues a deprecation warning if it is accessed, to let you know that you
4136
should really use a different feature.
4139
def __init__(self, dep_version, module, name,
4140
replacement_name, replacement_module=None):
4141
super(_CompatabilityThunkFeature, self).__init__()
4142
self._module = module
4143
if replacement_module is None:
4144
replacement_module = module
4145
self._replacement_module = replacement_module
4147
self._replacement_name = replacement_name
4148
self._dep_version = dep_version
4149
self._feature = None
4152
if self._feature is None:
4153
depr_msg = self._dep_version % ('%s.%s'
4154
% (self._module, self._name))
4155
use_msg = ' Use %s.%s instead.' % (self._replacement_module,
4156
self._replacement_name)
4157
symbol_versioning.warn(depr_msg + use_msg, DeprecationWarning)
4158
# Import the new feature and use it as a replacement for the
4160
mod = __import__(self._replacement_module, {}, {},
4161
[self._replacement_name])
4162
self._feature = getattr(mod, self._replacement_name)
4166
return self._feature._probe()
4169
class ModuleAvailableFeature(Feature):
4170
"""This is a feature than describes a module we want to be available.
4172
Declare the name of the module in __init__(), and then after probing, the
4173
module will be available as 'self.module'.
4175
:ivar module: The module if it is available, else None.
4178
def __init__(self, module_name):
4179
super(ModuleAvailableFeature, self).__init__()
4180
self.module_name = module_name
4184
self._module = __import__(self.module_name, {}, {}, [''])
4191
if self.available(): # Make sure the probe has been done
4195
def feature_name(self):
4196
return self.module_name
4199
# This is kept here for compatibility, it is recommended to use
4200
# 'bzrlib.tests.feature.paramiko' instead
4201
ParamikoFeature = _CompatabilityThunkFeature(
4202
deprecated_in((2,1,0)),
4203
'bzrlib.tests.features', 'ParamikoFeature', 'paramiko')
3841
4206
def probe_unicode_in_user_encoding():
3842
4207
"""Try to encode several unicode strings to use in unicode-aware tests.
3843
4208
Return first successfull match.