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
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
18
"""Tests of simple versioning operations"""
25
from bzrlib.tests import TestCaseInTempDir
25
from bzrlib.selftest import BzrTestBase, TestCaseInTempDir
26
26
from bzrlib.branch import Branch
27
from bzrlib.trace import mutter
28
from bzrlib.osutils import pathjoin
29
from bzrlib.workingtree import WorkingTree
29
logger = logging.getLogger('bzr.test.versioning')
32
33
class TestVersioning(TestCaseInTempDir):
35
36
"""Basic 'bzr mkdir' operation"""
37
38
self.run_bzr('init')
38
self.run_bzr('mkdir foo')
39
self.run_bzr('mkdir', 'foo')
39
40
self.assert_(os.path.isdir('foo'))
41
self.run_bzr('mkdir foo', retcode=3)
43
wt = WorkingTree.open('.')
45
delta = wt.changes_from(wt.basis_tree())
42
self.run_bzr('mkdir', 'foo', retcode=2)
44
from bzrlib.diff import compare_trees
45
from bzrlib.branch import Branch
48
delta = compare_trees(b.basis_tree(), b.working_tree())
47
50
self.log('delta.added = %r' % delta.added)
50
53
self.assertEquals(delta.added[0][0], 'foo')
51
54
self.failIf(delta.modified)
53
def test_mkdir_in_subdir(self):
54
"""'bzr mkdir' operation in subdirectory"""
57
self.run_bzr('mkdir dir')
58
self.assert_(os.path.isdir('dir'))
61
self.log('Run mkdir in subdir')
62
self.run_bzr('mkdir subdir')
63
self.assert_(os.path.isdir('subdir'))
66
wt = WorkingTree.open('.')
68
delta = wt.changes_from(wt.basis_tree())
70
self.log('delta.added = %r' % delta.added)
72
self.assertEquals(len(delta.added), 2)
73
self.assertEquals(delta.added[0][0], 'dir')
74
self.assertEquals(delta.added[1][0], pathjoin('dir','subdir'))
75
self.failIf(delta.modified)
77
def test_mkdir_w_nested_trees(self):
78
"""'bzr mkdir' with nested trees"""
89
self.run_bzr('mkdir dir a/dir a/b/dir')
90
self.failUnless(os.path.isdir('dir'))
91
self.failUnless(os.path.isdir('a/dir'))
92
self.failUnless(os.path.isdir('a/b/dir'))
94
wt = WorkingTree.open('.')
95
wt_a = WorkingTree.open('a')
96
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())
109
self.assertEquals(len(delta.added), 1)
110
self.assertEquals(delta.added[0][0], 'dir')
111
self.failIf(delta.modified)
56
def test_branch_add_in_unversioned(self):
57
"""Try to add a file in an unversioned directory.
59
"bzr add" adds the parent as necessary, but simple branch add
62
from bzrlib.branch import Branch
63
from bzrlib.errors import NotVersionedError
65
b = Branch.initialize('.')
67
self.build_tree(['foo/',
70
self.assertRaises(NotVersionedError,
76
def test_add_in_unversioned(self):
77
"""Try to add a file in an unversioned directory.
79
"bzr add" should add the parent(s) as necessary.
81
from bzrlib.branch import Branch
84
b = Branch.initialize('.')
86
self.build_tree(['inertiatic/', 'inertiatic/esp'])
87
eq(list(b.unknowns()), ['inertiatic'])
88
self.run_bzr('add', 'inertiatic/esp')
89
eq(list(b.unknowns()), [])
91
# Multiple unversioned parents
92
self.build_tree(['veil/', 'veil/cerpin/', 'veil/cerpin/taxt'])
93
eq(list(b.unknowns()), ['veil'])
94
self.run_bzr('add', 'veil/cerpin/taxt')
95
eq(list(b.unknowns()), [])
97
# Check whacky paths work
98
self.build_tree(['cicatriz/', 'cicatriz/esp'])
99
eq(list(b.unknowns()), ['cicatriz'])
100
self.run_bzr('add', 'inertiatic/../cicatriz/esp')
101
eq(list(b.unknowns()), [])
103
def test_add_in_versioned(self):
104
"""Try to add a file in a versioned directory.
106
"bzr add" should do this happily.
108
from bzrlib.branch import Branch
109
eq = self.assertEqual
111
b = Branch.initialize('.')
113
self.build_tree(['inertiatic/', 'inertiatic/esp'])
114
eq(list(b.unknowns()), ['inertiatic'])
115
self.run_bzr('add', '--no-recurse', 'inertiatic')
116
eq(list(b.unknowns()), ['inertiatic'+os.sep+'esp'])
117
self.run_bzr('add', 'inertiatic/esp')
118
eq(list(b.unknowns()), [])
120
def test_subdir_add(self):
121
"""Add in subdirectory should add only things from there down"""
123
from bzrlib.branch import Branch
125
eq = self.assertEqual
129
b = Branch.initialize('.')
130
self.build_tree(['src/', 'README'])
132
eq(sorted(b.unknowns()),
135
self.run_bzr('add', 'src')
137
self.build_tree(['src/foo.c'])
142
eq(sorted(b.unknowns()),
144
eq(len(b.inventory), 3)
148
eq(list(b.unknowns()), [])
113
152
def check_branch(self):
114
153
"""After all the above changes, run the check and upgrade commands.
116
155
The upgrade should be a no-op."""
117
b = Branch.open(u'.')
118
mutter('branch has %d revisions', b.revno())
120
mutter('check branch...')
157
debug('branch has %d revisions', b.revno())
159
debug('check branch...')
121
160
from bzrlib.check import check
125
165
class SubdirCommit(TestCaseInTempDir):
127
167
def test_subdir_commit(self):
130
170
eq = self.assertEqual
132
172
self.build_tree(['a/', 'b/'])
135
b = Branch.open(u'.')
137
177
for fn in ('a/one', 'b/two', 'top'):
138
178
file(fn, 'w').write('old contents')
141
run_bzr(['commit', '-m', 'first revision'])
181
run_bzr('commit', '-m', 'first revision')
143
183
for fn in ('a/one', 'b/two', 'top'):
144
184
file(fn, 'w').write('new contents')
146
mutter('start selective subdir commit')
147
run_bzr(['commit', 'a', '-m', 'commit a only'])
149
old = b.repository.revision_tree(b.get_rev_id(1))
150
new = b.repository.revision_tree(b.get_rev_id(2))
186
debug('start selective subdir commit')
187
run_bzr('commit', 'a', '-m', 'commit a only')
189
old = b.revision_tree(b.get_rev_id(1))
190
new = b.revision_tree(b.get_rev_id(2))
153
192
eq(new.get_file_by_path('b/two').read(), 'old contents')
154
193
eq(new.get_file_by_path('top').read(), 'old contents')
155
194
eq(new.get_file_by_path('a/one').read(), 'new contents')
159
197
# commit from here should do nothing
160
run_bzr(['commit', '.', '-m', 'commit subdir only', '--unchanged'])
161
v3 = b.repository.revision_tree(b.get_rev_id(3))
198
run_bzr('commit', '.', '-m', 'commit subdir only', '--unchanged')
199
v3 = b.revision_tree(b.get_rev_id(3))
163
200
eq(v3.get_file_by_path('b/two').read(), 'old contents')
164
201
eq(v3.get_file_by_path('top').read(), 'old contents')
165
202
eq(v3.get_file_by_path('a/one').read(), 'new contents')
168
204
# commit in subdirectory commits whole tree
169
run_bzr(['commit', '-m', 'commit whole tree from subdir'])
170
v4 = b.repository.revision_tree(b.get_rev_id(4))
172
eq(v4.get_file_by_path('b/two').read(), 'new contents')
205
run_bzr('commit', '-m', 'commit whole tree from subdir')
206
v4 = b.revision_tree(b.get_rev_id(4))
207
eq(v4.get_file_by_path('b/two').read(), 'new contents')
173
208
eq(v4.get_file_by_path('top').read(), 'new contents')
176
210
# TODO: factor out some kind of assert_tree_state() method
179
213
if __name__ == '__main__':