1
# Copyright (C) 2005 Canonical Ltd
1
# Copyright (C) 2005 by Canonical Ltd
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
5
5
# the Free Software Foundation; either version 2 of the License, or
6
6
# (at your option) any later version.
8
8
# This program is distributed in the hope that it will be useful,
9
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
11
# GNU General Public License for more details.
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
32
32
class TestVersioning(TestCaseInTempDir):
35
35
"""Basic 'bzr mkdir' operation"""
37
37
self.run_bzr('init')
38
self.run_bzr('mkdir foo')
38
self.run_bzr('mkdir', 'foo')
39
39
self.assert_(os.path.isdir('foo'))
41
self.run_bzr('mkdir foo', retcode=3)
41
self.run_bzr('mkdir', 'foo', retcode=3)
43
from bzrlib.diff import compare_trees
43
44
wt = WorkingTree.open('.')
45
delta = wt.changes_from(wt.basis_tree())
46
delta = compare_trees(wt.basis_tree(), wt)
47
48
self.log('delta.added = %r' % delta.added)
54
55
"""'bzr mkdir' operation in subdirectory"""
56
57
self.run_bzr('init')
57
self.run_bzr('mkdir dir')
58
self.run_bzr('mkdir', 'dir')
58
59
self.assert_(os.path.isdir('dir'))
61
62
self.log('Run mkdir in subdir')
62
self.run_bzr('mkdir subdir')
63
self.run_bzr('mkdir', 'subdir')
63
64
self.assert_(os.path.isdir('subdir'))
67
from bzrlib.diff import compare_trees
66
68
wt = WorkingTree.open('.')
68
delta = wt.changes_from(wt.basis_tree())
70
delta = compare_trees(wt.basis_tree(), wt)
70
72
self.log('delta.added = %r' % delta.added)
86
88
self.run_bzr('init')
89
self.run_bzr('mkdir dir a/dir a/b/dir')
91
self.run_bzr('mkdir', 'dir', 'a/dir', 'a/b/dir')
90
92
self.failUnless(os.path.isdir('dir'))
91
93
self.failUnless(os.path.isdir('a/dir'))
92
94
self.failUnless(os.path.isdir('a/b/dir'))
96
from bzrlib.diff import compare_trees
94
97
wt = WorkingTree.open('.')
95
98
wt_a = WorkingTree.open('a')
96
99
wt_b = WorkingTree.open('a/b')
98
delta = wt.changes_from(wt.basis_tree())
99
self.assertEquals(len(delta.added), 1)
100
self.assertEquals(delta.added[0][0], 'dir')
101
self.failIf(delta.modified)
103
delta = wt_a.changes_from(wt_a.basis_tree())
104
self.assertEquals(len(delta.added), 1)
105
self.assertEquals(delta.added[0][0], 'dir')
106
self.failIf(delta.modified)
108
delta = wt_b.changes_from(wt_b.basis_tree())
101
delta = compare_trees(wt.basis_tree(), wt)
102
self.assertEquals(len(delta.added), 1)
103
self.assertEquals(delta.added[0][0], 'dir')
104
self.failIf(delta.modified)
106
delta = compare_trees(wt_a.basis_tree(), wt_a)
107
self.assertEquals(len(delta.added), 1)
108
self.assertEquals(delta.added[0][0], 'dir')
109
self.failIf(delta.modified)
111
delta = compare_trees(wt_b.basis_tree(), wt_b)
109
112
self.assertEquals(len(delta.added), 1)
110
113
self.assertEquals(delta.added[0][0], 'dir')
111
114
self.failIf(delta.modified)
130
133
eq = self.assertEqual
132
135
self.build_tree(['a/', 'b/'])
135
138
b = Branch.open(u'.')
137
140
for fn in ('a/one', 'b/two', 'top'):
138
141
file(fn, 'w').write('old contents')
141
run_bzr(['commit', '-m', 'first revision'])
144
run_bzr('commit', '-m', 'first revision')
143
146
for fn in ('a/one', 'b/two', 'top'):
144
147
file(fn, 'w').write('new contents')
146
149
mutter('start selective subdir commit')
147
run_bzr(['commit', 'a', '-m', 'commit a only'])
150
run_bzr('commit', 'a', '-m', 'commit a only')
149
152
old = b.repository.revision_tree(b.get_rev_id(1))
150
153
new = b.repository.revision_tree(b.get_rev_id(2))
152
155
eq(new.get_file_by_path('b/two').read(), 'old contents')
153
156
eq(new.get_file_by_path('top').read(), 'old contents')
154
157
eq(new.get_file_by_path('a/one').read(), 'new contents')
157
160
# commit from here should do nothing
158
run_bzr(['commit', '.', '-m', 'commit subdir only', '--unchanged'])
161
run_bzr('commit', '.', '-m', 'commit subdir only', '--unchanged')
159
162
v3 = b.repository.revision_tree(b.get_rev_id(3))
160
163
eq(v3.get_file_by_path('b/two').read(), 'old contents')
161
164
eq(v3.get_file_by_path('top').read(), 'old contents')
162
165
eq(v3.get_file_by_path('a/one').read(), 'new contents')
164
167
# commit in subdirectory commits whole tree
165
run_bzr(['commit', '-m', 'commit whole tree from subdir'])
168
run_bzr('commit', '-m', 'commit whole tree from subdir')
166
169
v4 = b.repository.revision_tree(b.get_rev_id(4))
167
eq(v4.get_file_by_path('b/two').read(), 'new contents')
170
eq(v4.get_file_by_path('b/two').read(), 'new contents')
168
171
eq(v4.get_file_by_path('top').read(), 'new contents')
170
173
# TODO: factor out some kind of assert_tree_state() method
173
176
if __name__ == '__main__':