1
# Copyright (C) 2006 Canonical Ltd
1
# Copyright (C) 2006 by Canonical Ltd
2
2
# -*- coding: utf-8 -*-
4
4
# This program is free software; you can redistribute it and/or modify
5
5
# it under the terms of the GNU General Public License as published by
6
6
# the Free Software Foundation; either version 2 of the License, or
7
7
# (at your option) any later version.
9
9
# This program is distributed in the hope that it will be useful,
10
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
12
# GNU General Public License for more details.
14
14
# You should have received a copy of the GNU General Public License
15
15
# along with this program; if not, write to the Free Software
16
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
31
28
def test_update_standalone_trivial(self):
32
29
self.runbzr("init")
33
30
out, err = self.runbzr('update')
34
self.assertEqual('Tree is up to date at revision 0.\n', err)
35
self.assertEqual('', out)
37
def test_update_standalone_trivial_with_alias_up(self):
39
out, err = self.runbzr('up')
40
self.assertEqual('Tree is up to date at revision 0.\n', err)
41
self.assertEqual('', out)
43
def test_update_up_to_date_light_checkout(self):
31
self.assertEqual('Tree is up to date.\n', err)
32
self.assertEqual('', out)
34
def test_update_up_to_date_checkout(self):
44
35
self.make_branch_and_tree('branch')
45
self.runbzr('checkout --lightweight branch checkout')
36
self.runbzr('checkout branch checkout')
46
37
out, err = self.runbzr('update checkout')
47
self.assertEqual('Tree is up to date at revision 0.\n', err)
48
self.assertEqual('', out)
50
def test_update_up_to_date_checkout(self):
51
self.make_branch_and_tree('branch')
52
self.run_bzr('checkout', 'branch', 'checkout')
53
out, err = self.run_bzr('update', 'checkout')
54
self.assertEqual('Tree is up to date at revision 0.\n', err)
38
self.assertEqual('Tree is up to date.\n', err)
55
39
self.assertEqual('', out)
57
41
def test_update_out_of_date_standalone_tree(self):
58
42
# FIXME the default format has to change for this to pass
59
43
# because it currently uses the branch last-revision marker.
44
raise TestSkipped('default format too old')
60
45
self.make_branch_and_tree('branch')
62
self.runbzr('checkout --lightweight branch checkout')
47
self.runbzr('checkout branch checkout')
63
48
self.build_tree(['checkout/file'])
64
49
self.runbzr('add checkout/file')
65
50
self.runbzr('commit -m add-file checkout')
66
51
# now branch should be out of date
67
52
out,err = self.runbzr('update branch')
68
self.assertEqual('', out)
69
self.assertEqual('All changes applied successfully.\n'
70
'Updated to revision 1.\n', err)
53
self.assertEqual('Updated to revision 1.\n', out)
54
self.assertEqual('', err)
71
55
self.failUnlessExists('branch/file')
73
def test_update_out_of_date_light_checkout(self):
57
def test_update_out_of_date_checkout(self):
74
58
self.make_branch_and_tree('branch')
75
59
# make two checkouts
76
self.runbzr('checkout --lightweight branch checkout')
77
self.runbzr('checkout --lightweight branch checkout2')
60
self.runbzr('checkout branch checkout')
61
self.runbzr('checkout branch checkout2')
78
62
self.build_tree(['checkout/file'])
79
63
self.runbzr('add checkout/file')
80
64
self.runbzr('commit -m add-file checkout')
109
93
err.split('\n')[1:3])
110
94
self.assertContainsRe(err, 'Text conflict in file\n')
111
95
self.assertEqual('', out)
113
def test_smoke_update_checkout_bound_branch_local_commits(self):
114
# smoke test for doing an update of a checkout of a bound
115
# branch with local commits.
116
master = self.make_branch_and_tree('master')
117
# make a bound branch
118
self.run_bzr('checkout', 'master', 'child')
119
# get an object form of child
120
child = WorkingTree.open('child')
122
self.run_bzr('checkout', '--lightweight', 'child', 'checkout')
123
# get an object form of the checkout to manipulate
124
wt = WorkingTree.open('checkout')
126
a_file = file('master/file', 'wt')
130
master_tip = master.commit('add file')
132
a_file = file('child/file_b', 'wt')
135
child.add(['file_b'])
136
child_tip = child.commit('add file_b', local=True)
138
a_file = file('checkout/file_c', 'wt')
143
# now, update checkout ->
144
# get all three files and a pending merge.
145
out, err = self.run_bzr('update', 'checkout')
146
self.assertEqual('', out)
147
self.assertContainsRe(err, 'Updated to revision 1.\n'
148
'Your local commits will now show as'
150
self.assertEqual([master_tip, child_tip], wt.get_parent_ids())
151
self.failUnlessExists('checkout/file')
152
self.failUnlessExists('checkout/file_b')
153
self.failUnlessExists('checkout/file_c')
154
self.assertTrue(wt.has_filename('file_c'))
156
def test_update_with_merges(self):
157
# Test that 'bzr update' works correctly when you have
158
# an update in the master tree, and a lightweight checkout
159
# which has merged another branch
160
master = self.make_branch_and_tree('master')
161
self.build_tree(['master/file'])
163
master.commit('one', rev_id='m1')
165
self.build_tree(['checkout1/'])
166
checkout_dir = bzrdir.BzrDirMetaFormat1().initialize('checkout1')
167
branch.BranchReferenceFormat().initialize(checkout_dir, master.branch)
168
checkout1 = checkout_dir.create_workingtree('m1')
170
# Create a second branch, with an extra commit
171
other = master.bzrdir.sprout('other').open_workingtree()
172
self.build_tree(['other/file2'])
174
other.commit('other2', rev_id='o2')
176
# Create a new commit in the master branch
177
self.build_tree(['master/file3'])
178
master.add(['file3'])
179
master.commit('f3', rev_id='m2')
181
# Merge the other branch into checkout
182
os.chdir('checkout1')
183
self.run_bzr('merge', '../other')
185
self.assertEqual(['o2'], checkout1.get_parent_ids()[1:])
187
# At this point, 'commit' should fail, because we are out of date
188
self.run_bzr_error(["please run 'bzr update'"],
189
'commit', '-m', 'merged')
191
# This should not report about local commits being pending
192
# merges, because they were real merges
193
out, err = self.run_bzr('update')
194
self.assertEqual('', out)
195
self.assertEqual('All changes applied successfully.\n'
196
'Updated to revision 2.\n', err)
198
# The pending merges should still be there
199
self.assertEqual(['o2'], checkout1.get_parent_ids()[1:])
201
def test_readonly_lightweight_update(self):
202
"""Update a light checkout of a readonly branch"""
203
tree = self.make_branch_and_tree('branch')
204
readonly_branch = branch.Branch.open(self.get_readonly_url('branch'))
205
checkout = readonly_branch.create_checkout('checkout',
207
tree.commit('empty commit')
208
self.runbzr(['update', 'checkout'])