4
from bzrlib.selftest import TestCaseInTempDir, TestCase
4
from bzrlib.selftest import FunctionalTestCase, TestCase
5
5
from bzrlib.branch import Branch
6
6
from bzrlib.errors import NotBranchError, NotVersionedError
8
class TestSmartAdd(TestCaseInTempDir):
8
class TestSmartAdd(FunctionalTestCase):
10
10
def test_add_dot_from_root(self):
11
11
"""Test adding . from the root of the tree."""
12
12
from bzrlib.add import smart_add
13
13
paths = ("original/", "original/file1", "original/file2")
14
14
self.build_tree(paths)
15
branch = Branch.initialize(".")
16
smart_add((".",), recurse=True)
15
branch = Branch(".", init=True)
16
smart_add((".",), False, True)
18
18
self.assertNotEqual(branch.inventory.path2id(path), None)
22
22
from bzrlib.add import smart_add
23
23
paths = ("original/", "original/file1", "original/file2")
24
24
self.build_tree(paths)
25
branch = Branch.initialize(".")
25
branch = Branch(".", init=True)
26
26
os.chdir("original")
27
smart_add((".",), recurse=True)
27
smart_add((".",), False, True)
29
29
self.assertNotEqual(branch.inventory.path2id(path), None)
35
35
branch_paths = ("branch/", "branch/original/", "branch/original/file1",
36
36
"branch/original/file2")
37
37
self.build_tree(branch_paths)
38
branch = Branch.initialize("branch")
39
smart_add(("branch",))
38
branch = Branch("branch", init=True)
39
smart_add(("branch",), False, True)
41
41
self.assertNotEqual(branch.inventory.path2id(path), None)
43
43
def test_add_above_tree_preserves_tree(self):
44
44
"""Test nested trees are not affect by an add above them."""
45
from bzrlib.add import smart_add, add_reporter_null
45
from bzrlib.add import smart_add
47
46
paths = ("original/", "original/file1", "original/file2")
48
child_paths = ("path",)
47
child_paths = ("path")
49
48
full_child_paths = ("original/child", "original/child/path")
50
49
build_paths = ("original/", "original/file1", "original/file2",
51
50
"original/child/", "original/child/path")
53
51
self.build_tree(build_paths)
54
branch = Branch.initialize(".")
55
child_branch = Branch.initialize("original/child")
56
smart_add((".",), True, add_reporter_null)
52
branch = Branch(".", init=True)
53
child_branch = Branch("original/child", init=True)
54
smart_add((".",), False, True)
58
56
self.assertNotEqual((path, branch.inventory.path2id(path)),
68
66
from bzrlib.add import smart_add
69
67
paths = ("file1", "file2")
70
68
self.build_tree(paths)
71
branch = Branch.initialize(".")
69
branch = Branch(".", init=True)
70
smart_add(paths, False, True)
74
72
self.assertNotEqual(branch.inventory.path2id(path), None)
76
class TestSmartAddBranch(TestCaseInTempDir):
74
class TestSmartAddBranch(FunctionalTestCase):
77
75
"""Test smart adds with a specified branch."""
79
77
def test_add_dot_from_root(self):
81
79
from bzrlib.add import smart_add_branch
82
80
paths = ("original/", "original/file1", "original/file2")
83
81
self.build_tree(paths)
84
branch = Branch.initialize(".")
85
smart_add_branch(branch, (".",))
82
branch = Branch(".", init=True)
83
smart_add_branch(branch, (".",), False, True)
87
85
self.assertNotEqual(branch.inventory.path2id(path), None)
91
89
from bzrlib.add import smart_add_branch
92
90
paths = ("original/", "original/file1", "original/file2")
93
91
self.build_tree(paths)
94
branch = Branch.initialize(".")
92
branch = Branch(".", init=True)
95
93
os.chdir("original")
96
smart_add_branch(branch, (".",))
94
smart_add_branch(branch, (".",), False, True)
98
96
self.assertNotEqual(branch.inventory.path2id(path), None)
104
102
branch_paths = ("branch/", "branch/original/", "branch/original/file1",
105
103
"branch/original/file2")
106
104
self.build_tree(branch_paths)
107
branch = Branch.initialize("branch")
108
smart_add_branch(branch, ("branch",))
105
branch = Branch("branch", init=True)
106
smart_add_branch(branch, ("branch",), False, True)
109
107
for path in paths:
110
108
self.assertNotEqual(branch.inventory.path2id(path), None)
118
116
build_paths = ("original/", "original/file1", "original/file2",
119
117
"original/child/", "original/child/path")
120
118
self.build_tree(build_paths)
121
branch = Branch.initialize(".")
122
child_branch = Branch.initialize("original/child")
123
smart_add_branch(branch, (".",))
119
branch = Branch(".", init=True)
120
child_branch = Branch("original/child", init=True)
121
smart_add_branch(branch, (".",), False, True)
124
122
for path in paths:
125
123
self.assertNotEqual((path, branch.inventory.path2id(path)),
135
133
from bzrlib.add import smart_add_branch
136
134
paths = ("file1", "file2")
137
135
self.build_tree(paths)
138
branch = Branch.initialize(".")
139
smart_add_branch(branch, paths)
136
branch = Branch(".", init=True)
137
smart_add_branch(branch, paths, False, True)
140
138
for path in paths:
141
139
self.assertNotEqual(branch.inventory.path2id(path), None)
143
class TestAddCallbacks(TestCaseInTempDir):
146
from bzrlib.inventory import InventoryEntry
147
super(TestAddCallbacks, self).setUp()
148
self.entry = InventoryEntry("id", "name", "file", None)
150
def test_null_callback(self):
151
from bzrlib.add import add_reporter_null
152
add_reporter_null('path', 'file', self.entry)
154
def test_print_callback(self):
155
from bzrlib.add import add_reporter_print
156
from StringIO import StringIO
158
self.apply_redirected(None, stdout, None, add_reporter_print,
159
'path', 'file', self.entry)
160
self.assertEqual(stdout.getvalue(), "added path\n")