1
# Copyright (C) 2005 by Canonical Ltd
1
# Copyright (C) 2005 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
44
43
wt = WorkingTree.open('.')
46
delta = compare_trees(wt.basis_tree(), wt)
45
delta = wt.changes_from(wt.basis_tree())
48
47
self.log('delta.added = %r' % delta.added)
55
54
"""'bzr mkdir' operation in subdirectory"""
57
56
self.run_bzr('init')
58
self.run_bzr('mkdir', 'dir')
57
self.run_bzr('mkdir dir')
59
58
self.assert_(os.path.isdir('dir'))
62
61
self.log('Run mkdir in subdir')
63
self.run_bzr('mkdir', 'subdir')
62
self.run_bzr('mkdir subdir')
64
63
self.assert_(os.path.isdir('subdir'))
67
from bzrlib.diff import compare_trees
68
66
wt = WorkingTree.open('.')
70
delta = compare_trees(wt.basis_tree(), wt)
68
delta = wt.changes_from(wt.basis_tree())
72
70
self.log('delta.added = %r' % delta.added)
88
86
self.run_bzr('init')
91
self.run_bzr('mkdir', 'dir', 'a/dir', 'a/b/dir')
89
self.run_bzr('mkdir dir a/dir a/b/dir')
92
90
self.failUnless(os.path.isdir('dir'))
93
91
self.failUnless(os.path.isdir('a/dir'))
94
92
self.failUnless(os.path.isdir('a/b/dir'))
96
from bzrlib.diff import compare_trees
97
94
wt = WorkingTree.open('.')
98
95
wt_a = WorkingTree.open('a')
99
96
wt_b = WorkingTree.open('a/b')
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)
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())
112
109
self.assertEquals(len(delta.added), 1)
113
110
self.assertEquals(delta.added[0][0], 'dir')
114
111
self.failIf(delta.modified)
133
130
eq = self.assertEqual
135
132
self.build_tree(['a/', 'b/'])
138
135
b = Branch.open(u'.')
140
137
for fn in ('a/one', 'b/two', 'top'):
141
138
file(fn, 'w').write('old contents')
144
run_bzr('commit', '-m', 'first revision')
141
run_bzr(['commit', '-m', 'first revision'])
146
143
for fn in ('a/one', 'b/two', 'top'):
147
144
file(fn, 'w').write('new contents')
149
146
mutter('start selective subdir commit')
150
run_bzr('commit', 'a', '-m', 'commit a only')
147
run_bzr(['commit', 'a', '-m', 'commit a only'])
152
149
old = b.repository.revision_tree(b.get_rev_id(1))
153
150
new = b.repository.revision_tree(b.get_rev_id(2))
155
153
eq(new.get_file_by_path('b/two').read(), 'old contents')
156
154
eq(new.get_file_by_path('top').read(), 'old contents')
157
155
eq(new.get_file_by_path('a/one').read(), 'new contents')
160
159
# commit from here should do nothing
161
run_bzr('commit', '.', '-m', 'commit subdir only', '--unchanged')
160
run_bzr(['commit', '.', '-m', 'commit subdir only', '--unchanged'])
162
161
v3 = b.repository.revision_tree(b.get_rev_id(3))
163
163
eq(v3.get_file_by_path('b/two').read(), 'old contents')
164
164
eq(v3.get_file_by_path('top').read(), 'old contents')
165
165
eq(v3.get_file_by_path('a/one').read(), 'new contents')
167
168
# commit in subdirectory commits whole tree
168
run_bzr('commit', '-m', 'commit whole tree from subdir')
169
run_bzr(['commit', '-m', 'commit whole tree from subdir'])
169
170
v4 = b.repository.revision_tree(b.get_rev_id(4))
170
eq(v4.get_file_by_path('b/two').read(), 'new contents')
172
eq(v4.get_file_by_path('b/two').read(), 'new contents')
171
173
eq(v4.get_file_by_path('top').read(), 'new contents')
173
176
# TODO: factor out some kind of assert_tree_state() method
176
179
if __name__ == '__main__':