57
52
ue_scenarios = [('dirstate_Python',
58
53
{'update_entry': dirstate.py_update_entry})]
59
if has_dirstate_helpers_c:
60
c_scenario = ('dirstate_C',
61
{'update_entry': _dirstate_helpers_c.update_entry})
62
ue_scenarios.append(c_scenario)
54
if compiled_dirstate_helpers_feature.available():
55
update_entry = compiled_dirstate_helpers_feature.module.update_entry
56
pyrex_scenario = ('dirstate_Pyrex', {'update_entry': update_entry})
57
ue_scenarios.append(pyrex_scenario)
63
58
process_entry_tests, remaining_tests = tests.split_suite_by_condition(
64
59
remaining_tests, tests.condition_isinstance(TestUpdateEntry))
65
60
tests.multiply_tests(process_entry_tests,
70
65
pe_scenarios = [('dirstate_Python',
71
66
{'_process_entry': dirstate.ProcessEntryPython})]
72
if has_dirstate_helpers_c:
73
c_scenario = ('dirstate_C',
74
{'_process_entry': _dirstate_helpers_c.ProcessEntryC})
75
pe_scenarios.append(c_scenario)
67
if compiled_dirstate_helpers_feature.available():
68
process_entry = compiled_dirstate_helpers_feature.module.ProcessEntryC
69
pyrex_scenario = ('dirstate_Pyrex', {'_process_entry': process_entry})
70
pe_scenarios.append(pyrex_scenario)
76
71
process_entry_tests, remaining_tests = tests.split_suite_by_condition(
77
72
remaining_tests, tests.condition_isinstance(TestProcessEntry))
78
73
tests.multiply_tests(process_entry_tests,
247
242
class TestBisectPathLeft(tests.TestCase, TestBisectPathMixin):
248
"""Run all Bisect Path tests against _bisect_path_left_py."""
243
"""Run all Bisect Path tests against _bisect_path_left."""
250
245
def get_bisect_path(self):
251
from bzrlib._dirstate_helpers_py import _bisect_path_left_py
252
return _bisect_path_left_py
246
from bzrlib._dirstate_helpers_py import _bisect_path_left
247
return _bisect_path_left
254
249
def get_bisect(self):
255
250
return bisect.bisect_left, 0
258
253
class TestCompiledBisectPathLeft(TestBisectPathLeft):
259
"""Run all Bisect Path tests against _bisect_path_right_c"""
254
"""Run all Bisect Path tests against _bisect_path_lect"""
261
_test_needs_features = [CompiledDirstateHelpersFeature]
256
_test_needs_features = [compiled_dirstate_helpers_feature]
263
258
def get_bisect_path(self):
264
from bzrlib._dirstate_helpers_c import _bisect_path_left_c
265
return _bisect_path_left_c
259
from bzrlib._dirstate_helpers_pyx import _bisect_path_left
260
return _bisect_path_left
268
263
class TestBisectPathRight(tests.TestCase, TestBisectPathMixin):
269
"""Run all Bisect Path tests against _bisect_path_right_py"""
264
"""Run all Bisect Path tests against _bisect_path_right"""
271
266
def get_bisect_path(self):
272
from bzrlib._dirstate_helpers_py import _bisect_path_right_py
273
return _bisect_path_right_py
267
from bzrlib._dirstate_helpers_py import _bisect_path_right
268
return _bisect_path_right
275
270
def get_bisect(self):
276
271
return bisect.bisect_right, -1
279
274
class TestCompiledBisectPathRight(TestBisectPathRight):
280
"""Run all Bisect Path tests against _bisect_path_right_c"""
275
"""Run all Bisect Path tests against _bisect_path_right"""
282
_test_needs_features = [CompiledDirstateHelpersFeature]
277
_test_needs_features = [compiled_dirstate_helpers_feature]
284
279
def get_bisect_path(self):
285
from bzrlib._dirstate_helpers_c import _bisect_path_right_c
286
return _bisect_path_right_c
280
from bzrlib._dirstate_helpers_pyx import _bisect_path_right
281
return _bisect_path_right
289
284
class TestBisectDirblock(tests.TestCase):
664
659
class TestCompiledCmpPathByDirblock(TestCmpPathByDirblock):
665
660
"""Test the pyrex implementation of _cmp_path_by_dirblock"""
667
_test_needs_features = [CompiledDirstateHelpersFeature]
662
_test_needs_features = [compiled_dirstate_helpers_feature]
669
664
def get_cmp_by_dirs(self):
670
from bzrlib._dirstate_helpers_c import _cmp_path_by_dirblock_c
671
return _cmp_path_by_dirblock_c
665
from bzrlib._dirstate_helpers_pyx import _cmp_path_by_dirblock
666
return _cmp_path_by_dirblock
674
669
class TestMemRChr(tests.TestCase):
675
670
"""Test memrchr functionality"""
677
_test_needs_features = [CompiledDirstateHelpersFeature]
672
_test_needs_features = [compiled_dirstate_helpers_feature]
679
674
def assertMemRChr(self, expected, s, c):
680
from bzrlib._dirstate_helpers_c import _py_memrchr
675
from bzrlib._dirstate_helpers_pyx import _py_memrchr
681
676
self.assertEqual(expected, _py_memrchr(s, c))
683
678
def test_missing(self):
758
757
class TestCompiledReadDirblocks(TestReadDirblocks):
759
758
"""Test the pyrex implementation of _read_dirblocks"""
761
_test_needs_features = [CompiledDirstateHelpersFeature]
760
_test_needs_features = [compiled_dirstate_helpers_feature]
763
762
def get_read_dirblocks(self):
764
from bzrlib._dirstate_helpers_c import _read_dirblocks_c
765
return _read_dirblocks_c
763
from bzrlib._dirstate_helpers_pyx import _read_dirblocks
764
return _read_dirblocks
768
767
class TestUsingCompiledIfAvailable(tests.TestCase):
769
768
"""Check that any compiled functions that are available are the default.
771
770
It is possible to have typos, etc in the import line, such that
772
_dirstate_helpers_c is actually available, but the compiled functions are
771
_dirstate_helpers_pyx is actually available, but the compiled functions are
776
775
def test_bisect_dirblock(self):
777
if CompiledDirstateHelpersFeature.available():
778
from bzrlib._dirstate_helpers_c import bisect_dirblock_c
779
self.assertIs(bisect_dirblock_c, dirstate.bisect_dirblock)
776
if compiled_dirstate_helpers_feature.available():
777
from bzrlib._dirstate_helpers_pyx import bisect_dirblock
781
from bzrlib._dirstate_helpers_py import bisect_dirblock_py
782
self.assertIs(bisect_dirblock_py, dirstate.bisect_dirblock)
779
from bzrlib._dirstate_helpers_py import bisect_dirblock
780
self.assertIs(bisect_dirblock, dirstate.bisect_dirblock)
784
782
def test__bisect_path_left(self):
785
if CompiledDirstateHelpersFeature.available():
786
from bzrlib._dirstate_helpers_c import _bisect_path_left_c
787
self.assertIs(_bisect_path_left_c, dirstate._bisect_path_left)
783
if compiled_dirstate_helpers_feature.available():
784
from bzrlib._dirstate_helpers_pyx import _bisect_path_left
789
from bzrlib._dirstate_helpers_py import _bisect_path_left_py
790
self.assertIs(_bisect_path_left_py, dirstate._bisect_path_left)
786
from bzrlib._dirstate_helpers_py import _bisect_path_left
787
self.assertIs(_bisect_path_left, dirstate._bisect_path_left)
792
789
def test__bisect_path_right(self):
793
if CompiledDirstateHelpersFeature.available():
794
from bzrlib._dirstate_helpers_c import _bisect_path_right_c
795
self.assertIs(_bisect_path_right_c, dirstate._bisect_path_right)
790
if compiled_dirstate_helpers_feature.available():
791
from bzrlib._dirstate_helpers_pyx import _bisect_path_right
797
from bzrlib._dirstate_helpers_py import _bisect_path_right_py
798
self.assertIs(_bisect_path_right_py, dirstate._bisect_path_right)
793
from bzrlib._dirstate_helpers_py import _bisect_path_right
794
self.assertIs(_bisect_path_right, dirstate._bisect_path_right)
800
796
def test_cmp_by_dirs(self):
801
if CompiledDirstateHelpersFeature.available():
802
from bzrlib._dirstate_helpers_c import cmp_by_dirs_c
803
self.assertIs(cmp_by_dirs_c, dirstate.cmp_by_dirs)
797
if compiled_dirstate_helpers_feature.available():
798
from bzrlib._dirstate_helpers_pyx import cmp_by_dirs
805
from bzrlib._dirstate_helpers_py import cmp_by_dirs_py
806
self.assertIs(cmp_by_dirs_py, dirstate.cmp_by_dirs)
800
from bzrlib._dirstate_helpers_py import cmp_by_dirs
801
self.assertIs(cmp_by_dirs, dirstate.cmp_by_dirs)
808
803
def test__read_dirblocks(self):
809
if CompiledDirstateHelpersFeature.available():
810
from bzrlib._dirstate_helpers_c import _read_dirblocks_c
811
self.assertIs(_read_dirblocks_c, dirstate._read_dirblocks)
804
if compiled_dirstate_helpers_feature.available():
805
from bzrlib._dirstate_helpers_pyx import _read_dirblocks
813
from bzrlib._dirstate_helpers_py import _read_dirblocks_py
814
self.assertIs(_read_dirblocks_py, dirstate._read_dirblocks)
807
from bzrlib._dirstate_helpers_py import _read_dirblocks
808
self.assertIs(_read_dirblocks, dirstate._read_dirblocks)
816
810
def test_update_entry(self):
817
if CompiledDirstateHelpersFeature.available():
818
from bzrlib._dirstate_helpers_c import update_entry
819
self.assertIs(update_entry, dirstate.update_entry)
811
if compiled_dirstate_helpers_feature.available():
812
from bzrlib._dirstate_helpers_pyx import update_entry
821
from bzrlib.dirstate import py_update_entry
822
self.assertIs(py_update_entry, dirstate.py_update_entry)
814
from bzrlib.dirstate import update_entry
815
self.assertIs(update_entry, dirstate.update_entry)
824
817
def test_process_entry(self):
825
if CompiledDirstateHelpersFeature.available():
826
from bzrlib._dirstate_helpers_c import ProcessEntryC
818
if compiled_dirstate_helpers_feature.available():
819
from bzrlib._dirstate_helpers_pyx import ProcessEntryC
827
820
self.assertIs(ProcessEntryC, dirstate._process_entry)
829
822
from bzrlib.dirstate import ProcessEntryPython
1301
1286
self.assertEqual(sorted(expected), sorted(file_ids))
1288
def test_exceptions_raised(self):
1289
# This is a direct test of bug #495023, it relies on osutils.is_inside
1290
# getting called in an inner function. Which makes it a bit brittle,
1291
# but at least it does reproduce the bug.
1292
tree = self.make_branch_and_tree('tree')
1293
self.build_tree(['tree/file', 'tree/dir/', 'tree/dir/sub',
1294
'tree/dir2/', 'tree/dir2/sub2'])
1295
tree.add(['file', 'dir', 'dir/sub', 'dir2', 'dir2/sub2'])
1296
tree.commit('first commit')
1298
self.addCleanup(tree.unlock)
1299
basis_tree = tree.basis_tree()
1300
def is_inside_raises(*args, **kwargs):
1301
raise RuntimeError('stop this')
1302
self.overrideAttr(osutils, 'is_inside', is_inside_raises)
1303
self.assertListRaises(RuntimeError, tree.iter_changes, basis_tree)
1303
1305
def test_simple_changes(self):
1304
1306
tree = self.make_branch_and_tree('tree')
1305
1307
self.build_tree(['tree/file'])