~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_update.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2007-03-28 06:58:22 UTC
  • mfrom: (2379.2.3 hpss-chroot)
  • Revision ID: pqm@pqm.ubuntu.com-20070328065822-999550a858a3ced3
(robertc) Fix chroot urls to not expose the url of the transport they are protecting, allowing regular url operations to work on them. (Robert Collins, Andrew Bennetts)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006-2012, 2016 Canonical Ltd
 
1
# Copyright (C) 2006 Canonical Ltd
 
2
# -*- coding: utf-8 -*-
2
3
#
3
4
# This program is free software; you can redistribute it and/or modify
4
5
# it under the terms of the GNU General Public License as published by
12
13
#
13
14
# You should have received a copy of the GNU General Public License
14
15
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
 
17
18
 
18
19
"""Tests for the update command of bzr."""
19
20
 
20
21
import os
21
22
 
22
 
from bzrlib import (
23
 
    branch,
24
 
    bzrdir,
25
 
    osutils,
26
 
    tests,
27
 
    workingtree,
28
 
    )
29
 
from bzrlib.tests.script import ScriptRunner
30
 
 
31
 
 
32
 
class TestUpdate(tests.TestCaseWithTransport):
 
23
from bzrlib import branch, bzrdir
 
24
from bzrlib.tests import TestSkipped
 
25
from bzrlib.tests.blackbox import ExternalBase
 
26
from bzrlib.workingtree import WorkingTree
 
27
 
 
28
 
 
29
class TestUpdate(ExternalBase):
33
30
 
34
31
    def test_update_standalone_trivial(self):
35
 
        self.make_branch_and_tree('.')
36
 
        out, err = self.run_bzr('update')
37
 
        self.assertEqual(
38
 
            'Tree is up to date at revision 0 of branch %s\n' % self.test_dir,
39
 
            err)
40
 
        self.assertEqual('', out)
41
 
 
42
 
    def test_update_quiet(self):
43
 
        self.make_branch_and_tree('.')
44
 
        out, err = self.run_bzr('update --quiet')
45
 
        self.assertEqual('', err)
 
32
        self.runbzr("init")
 
33
        out, err = self.runbzr('update')
 
34
        self.assertEqual('Tree is up to date at revision 0.\n', err)
46
35
        self.assertEqual('', out)
47
36
 
48
37
    def test_update_standalone_trivial_with_alias_up(self):
49
 
        self.make_branch_and_tree('.')
50
 
        out, err = self.run_bzr('up')
51
 
        self.assertEqual('Tree is up to date at revision 0 of branch %s\n'
52
 
                         % self.test_dir,
53
 
                         err)
 
38
        self.runbzr("init")
 
39
        out, err = self.runbzr('up')
 
40
        self.assertEqual('Tree is up to date at revision 0.\n', err)
54
41
        self.assertEqual('', out)
55
42
 
56
43
    def test_update_up_to_date_light_checkout(self):
57
44
        self.make_branch_and_tree('branch')
58
 
        self.run_bzr('checkout --lightweight branch checkout')
59
 
        out, err = self.run_bzr('update checkout')
60
 
        self.assertEqual('Tree is up to date at revision 0 of branch %s\n'
61
 
                         % osutils.pathjoin(self.test_dir, 'branch'),
62
 
                         err)
 
45
        self.runbzr('checkout --lightweight branch checkout')
 
46
        out, err = self.runbzr('update checkout')
 
47
        self.assertEqual('Tree is up to date at revision 0.\n', err)
63
48
        self.assertEqual('', out)
64
49
 
65
50
    def test_update_up_to_date_checkout(self):
66
51
        self.make_branch_and_tree('branch')
67
 
        self.run_bzr('checkout branch checkout')
68
 
        sr = ScriptRunner()
69
 
        sr.run_script(self, '''
70
 
$ bzr update checkout
71
 
2>Tree is up to date at revision 0 of branch .../branch
72
 
''')
 
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)
 
55
        self.assertEqual('', out)
73
56
 
74
57
    def test_update_out_of_date_standalone_tree(self):
75
58
        # FIXME the default format has to change for this to pass
76
59
        # because it currently uses the branch last-revision marker.
77
60
        self.make_branch_and_tree('branch')
78
61
        # make a checkout
79
 
        self.run_bzr('checkout --lightweight branch checkout')
 
62
        self.runbzr('checkout --lightweight branch checkout')
80
63
        self.build_tree(['checkout/file'])
81
 
        self.run_bzr('add checkout/file')
82
 
        self.run_bzr('commit -m add-file checkout')
 
64
        self.runbzr('add checkout/file')
 
65
        self.runbzr('commit -m add-file checkout')
83
66
        # now branch should be out of date
84
 
        out,err = self.run_bzr('update branch')
 
67
        out,err = self.runbzr('update branch')
85
68
        self.assertEqual('', out)
86
 
        self.assertEqualDiff("""+N  file
87
 
All changes applied successfully.
88
 
Updated to revision 1 of branch %s
89
 
""" % osutils.pathjoin(self.test_dir, 'branch',),
90
 
                         err)
91
 
        self.assertPathExists('branch/file')
 
69
        self.assertEqual('All changes applied successfully.\n'
 
70
                         'Updated to revision 1.\n', err)
 
71
        self.failUnlessExists('branch/file')
92
72
 
93
73
    def test_update_out_of_date_light_checkout(self):
94
74
        self.make_branch_and_tree('branch')
95
75
        # make two checkouts
96
 
        self.run_bzr('checkout --lightweight branch checkout')
97
 
        self.run_bzr('checkout --lightweight branch checkout2')
 
76
        self.runbzr('checkout --lightweight branch checkout')
 
77
        self.runbzr('checkout --lightweight branch checkout2')
98
78
        self.build_tree(['checkout/file'])
99
 
        self.run_bzr('add checkout/file')
100
 
        self.run_bzr('commit -m add-file checkout')
 
79
        self.runbzr('add checkout/file')
 
80
        self.runbzr('commit -m add-file checkout')
101
81
        # now checkout2 should be out of date
102
 
        out,err = self.run_bzr('update checkout2')
103
 
        self.assertEqualDiff('''+N  file
104
 
All changes applied successfully.
105
 
Updated to revision 1 of branch %s
106
 
''' % osutils.pathjoin(self.test_dir, 'branch',),
 
82
        out,err = self.runbzr('update checkout2')
 
83
        self.assertEqual('All changes applied successfully.\n'
 
84
                         'Updated to revision 1.\n',
107
85
                         err)
108
86
        self.assertEqual('', out)
109
87
 
110
88
    def test_update_conflicts_returns_2(self):
111
89
        self.make_branch_and_tree('branch')
112
90
        # make two checkouts
113
 
        self.run_bzr('checkout --lightweight branch checkout')
 
91
        self.runbzr('checkout --lightweight branch checkout')
114
92
        self.build_tree(['checkout/file'])
115
 
        self.run_bzr('add checkout/file')
116
 
        self.run_bzr('commit -m add-file checkout')
117
 
        self.run_bzr('checkout --lightweight branch checkout2')
 
93
        self.runbzr('add checkout/file')
 
94
        self.runbzr('commit -m add-file checkout')
 
95
        self.runbzr('checkout --lightweight branch checkout2')
118
96
        # now alter file in checkout
119
97
        a_file = file('checkout/file', 'wt')
120
98
        a_file.write('Foo')
121
99
        a_file.close()
122
 
        self.run_bzr('commit -m checnge-file checkout')
 
100
        self.runbzr('commit -m checnge-file checkout')
123
101
        # now checkout2 should be out of date
124
102
        # make a local change to file
125
103
        a_file = file('checkout2/file', 'wt')
126
104
        a_file.write('Bar')
127
105
        a_file.close()
128
 
        out,err = self.run_bzr('update checkout2', retcode=1)
129
 
        self.assertEqualDiff(''' M  file
130
 
Text conflict in file
131
 
1 conflicts encountered.
132
 
Updated to revision 2 of branch %s
133
 
''' % osutils.pathjoin(self.test_dir, 'branch',),
134
 
                         err)
 
106
        out,err = self.runbzr('update checkout2', retcode=1)
 
107
        self.assertEqual(['1 conflicts encountered.',
 
108
                          'Updated to revision 2.'],
 
109
                         err.split('\n')[1:3])
 
110
        self.assertContainsRe(err, 'Text conflict in file\n')
135
111
        self.assertEqual('', out)
136
112
 
137
113
    def test_smoke_update_checkout_bound_branch_local_commits(self):
138
114
        # smoke test for doing an update of a checkout of a bound
139
115
        # branch with local commits.
140
116
        master = self.make_branch_and_tree('master')
141
 
        master.commit('first commit')
142
117
        # make a bound branch
143
 
        self.run_bzr('checkout master child')
 
118
        self.run_bzr('checkout', 'master', 'child')
 
119
        # get an object form of child
 
120
        child = WorkingTree.open('child')
144
121
        # check that out
145
 
        self.run_bzr('checkout --lightweight child checkout')
 
122
        self.run_bzr('checkout', '--lightweight', 'child', 'checkout')
146
123
        # get an object form of the checkout to manipulate
147
 
        wt = workingtree.WorkingTree.open('checkout')
 
124
        wt = WorkingTree.open('checkout')
148
125
        # change master
149
126
        a_file = file('master/file', 'wt')
150
127
        a_file.write('Foo')
155
132
        a_file = file('child/file_b', 'wt')
156
133
        a_file.write('Foo')
157
134
        a_file.close()
158
 
        # get an object form of child
159
 
        child = workingtree.WorkingTree.open('child')
160
135
        child.add(['file_b'])
161
136
        child_tip = child.commit('add file_b', local=True)
162
137
        # check checkout
167
142
 
168
143
        # now, update checkout ->
169
144
        # get all three files and a pending merge.
170
 
        out, err = self.run_bzr('update checkout')
 
145
        out, err = self.run_bzr('update', 'checkout')
171
146
        self.assertEqual('', out)
172
 
        self.assertEqualDiff("""+N  file_b
173
 
All changes applied successfully.
174
 
+N  file
175
 
All changes applied successfully.
176
 
Updated to revision 2 of branch %s
177
 
Your local commits will now show as pending merges with 'bzr status', and can be committed with 'bzr commit'.
178
 
""" % osutils.pathjoin(self.test_dir, 'master',),
179
 
                         err)
 
147
        self.assertContainsRe(err, 'Updated to revision 1.\n'
 
148
                                   'Your local commits will now show as'
 
149
                                   ' pending merges')
180
150
        self.assertEqual([master_tip, child_tip], wt.get_parent_ids())
181
 
        self.assertPathExists('checkout/file')
182
 
        self.assertPathExists('checkout/file_b')
183
 
        self.assertPathExists('checkout/file_c')
 
151
        self.failUnlessExists('checkout/file')
 
152
        self.failUnlessExists('checkout/file_b')
 
153
        self.failUnlessExists('checkout/file_c')
184
154
        self.assertTrue(wt.has_filename('file_c'))
185
155
 
186
156
    def test_update_with_merges(self):
194
164
 
195
165
        self.build_tree(['checkout1/'])
196
166
        checkout_dir = bzrdir.BzrDirMetaFormat1().initialize('checkout1')
197
 
        checkout_dir.set_branch_reference(master.branch)
 
167
        branch.BranchReferenceFormat().initialize(checkout_dir, master.branch)
198
168
        checkout1 = checkout_dir.create_workingtree('m1')
199
169
 
200
170
        # Create a second branch, with an extra commit
210
180
 
211
181
        # Merge the other branch into checkout
212
182
        os.chdir('checkout1')
213
 
        self.run_bzr('merge ../other')
 
183
        self.run_bzr('merge', '../other')
214
184
 
215
185
        self.assertEqual(['o2'], checkout1.get_parent_ids()[1:])
216
186
 
217
187
        # At this point, 'commit' should fail, because we are out of date
218
188
        self.run_bzr_error(["please run 'bzr update'"],
219
 
                           'commit -m merged')
 
189
                           'commit', '-m', 'merged')
220
190
 
221
191
        # This should not report about local commits being pending
222
192
        # merges, because they were real merges
223
193
        out, err = self.run_bzr('update')
224
194
        self.assertEqual('', out)
225
 
        self.assertEqualDiff('''+N  file3
226
 
All changes applied successfully.
227
 
Updated to revision 2 of branch %s
228
 
''' % osutils.pathjoin(self.test_dir, 'master',),
229
 
                         err)
 
195
        self.assertEqual('All changes applied successfully.\n'
 
196
                         'Updated to revision 2.\n', err)
 
197
 
230
198
        # The pending merges should still be there
231
199
        self.assertEqual(['o2'], checkout1.get_parent_ids()[1:])
232
200
 
237
205
        checkout = readonly_branch.create_checkout('checkout',
238
206
                                                   lightweight=True)
239
207
        tree.commit('empty commit')
240
 
        self.run_bzr('update checkout')
241
 
 
242
 
    def test_update_with_merge_merged_to_master(self):
243
 
        # Test that 'bzr update' works correctly when you have
244
 
        # an update in the master tree, and a [lightweight or otherwise]
245
 
        # checkout which has merge a revision merged to master already.
246
 
        master = self.make_branch_and_tree('master')
247
 
        self.build_tree(['master/file'])
248
 
        master.add(['file'])
249
 
        master.commit('one', rev_id='m1')
250
 
 
251
 
        self.build_tree(['checkout1/'])
252
 
        checkout_dir = bzrdir.BzrDirMetaFormat1().initialize('checkout1')
253
 
        checkout_dir.set_branch_reference(master.branch)
254
 
        checkout1 = checkout_dir.create_workingtree('m1')
255
 
 
256
 
        # Create a second branch, with an extra commit
257
 
        other = master.bzrdir.sprout('other').open_workingtree()
258
 
        self.build_tree(['other/file2'])
259
 
        other.add(['file2'])
260
 
        other.commit('other2', rev_id='o2')
261
 
 
262
 
        # Merge the other branch into checkout -  'start reviewing a patch'
263
 
        checkout1.merge_from_branch(other.branch)
264
 
        self.assertEqual(['o2'], checkout1.get_parent_ids()[1:])
265
 
 
266
 
        # Create a new commit in the master branch - 'someone else lands its'
267
 
        master.merge_from_branch(other.branch)
268
 
        master.commit('f3', rev_id='m2')
269
 
 
270
 
        # This should not report about local commits being pending
271
 
        # merges, because they were real merges (but are now gone).
272
 
        # It should perhaps report on them.
273
 
        out, err = self.run_bzr('update', working_dir='checkout1')
274
 
        self.assertEqual('', out)
275
 
        self.assertEqualDiff('''All changes applied successfully.
276
 
Updated to revision 2 of branch %s
277
 
''' % osutils.pathjoin(self.test_dir, 'master',),
278
 
                         err)
279
 
        # The pending merges should still be there
280
 
        self.assertEqual([], checkout1.get_parent_ids()[1:])
281
 
 
282
 
    def test_update_dash_r(self):
283
 
        master = self.make_branch_and_tree('master')
284
 
        os.chdir('master')
285
 
        self.build_tree(['./file1'])
286
 
        master.add(['file1'])
287
 
        master.commit('one', rev_id='m1')
288
 
        self.build_tree(['./file2'])
289
 
        master.add(['file2'])
290
 
        master.commit('two', rev_id='m2')
291
 
 
292
 
        sr = ScriptRunner()
293
 
        sr.run_script(self, '''
294
 
$ bzr update -r 1
295
 
2>-D  file2
296
 
2>All changes applied successfully.
297
 
2>Updated to revision 1 of .../master
298
 
''')
299
 
        self.assertPathExists('./file1')
300
 
        self.assertPathDoesNotExist('./file2')
301
 
        self.assertEqual(['m1'], master.get_parent_ids())
302
 
 
303
 
    def test_update_dash_r_outside_history(self):
304
 
        """Ensure that we can update -r to dotted revisions.
305
 
        """
306
 
        master = self.make_branch_and_tree('master')
307
 
        self.build_tree(['master/file1'])
308
 
        master.add(['file1'])
309
 
        master.commit('one', rev_id='m1')
310
 
 
311
 
        # Create a second branch, with extra commits
312
 
        other = master.bzrdir.sprout('other').open_workingtree()
313
 
        self.build_tree(['other/file2', 'other/file3'])
314
 
        other.add(['file2'])
315
 
        other.commit('other2', rev_id='o2')
316
 
        other.add(['file3'])
317
 
        other.commit('other3', rev_id='o3')
318
 
 
319
 
        os.chdir('master')
320
 
        self.run_bzr('merge ../other')
321
 
        master.commit('merge', rev_id='merge')
322
 
 
323
 
        # Switch to o2. file3 was added only in o3 and should be deleted.
324
 
        out, err = self.run_bzr('update -r revid:o2')
325
 
        self.assertContainsRe(err, '-D\s+file3')
326
 
        self.assertContainsRe(err, 'All changes applied successfully\.')
327
 
        self.assertContainsRe(err, 'Updated to revision 1.1.1 of branch .*')
328
 
 
329
 
        # Switch back to latest
330
 
        out, err = self.run_bzr('update')
331
 
        self.assertContainsRe(err, '\+N\s+file3')
332
 
        self.assertContainsRe(err, 'All changes applied successfully\.')
333
 
        self.assertContainsRe(err, 'Updated to revision 2 of branch .*')
334
 
 
335
 
    def test_update_dash_r_in_master(self):
336
 
        # Test that 'bzr update' works correctly when you have
337
 
        # an update in the master tree,
338
 
        master = self.make_branch_and_tree('master')
339
 
        self.build_tree(['master/file1'])
340
 
        master.add(['file1'])
341
 
        master.commit('one', rev_id='m1')
342
 
 
343
 
        self.run_bzr('checkout master checkout')
344
 
 
345
 
        # add a revision in the master.
346
 
        self.build_tree(['master/file2'])
347
 
        master.add(['file2'])
348
 
        master.commit('two', rev_id='m2')
349
 
 
350
 
        os.chdir('checkout')
351
 
        sr = ScriptRunner()
352
 
        sr.run_script(self, '''
353
 
$ bzr update -r revid:m2
354
 
2>+N  file2
355
 
2>All changes applied successfully.
356
 
2>Updated to revision 2 of branch .../master
357
 
''')
358
 
 
359
 
    def test_update_show_base(self):
360
 
        """bzr update support --show-base
361
 
 
362
 
        see https://bugs.launchpad.net/bzr/+bug/202374"""
363
 
 
364
 
        tree=self.make_branch_and_tree('.')
365
 
 
366
 
        f = open('hello','wt')
367
 
        f.write('foo')
368
 
        f.close()
369
 
        tree.add('hello')
370
 
        tree.commit('fie')
371
 
 
372
 
        f = open('hello','wt')
373
 
        f.write('fee')
374
 
        f.close()
375
 
        tree.commit('fee')
376
 
 
377
 
        #tree.update() gives no such revision, so ...
378
 
        self.run_bzr(['update','-r1'])
379
 
 
380
 
        #create conflict
381
 
        f = open('hello','wt')
382
 
        f.write('fie')
383
 
        f.close()
384
 
 
385
 
        out, err = self.run_bzr(['update','--show-base'],retcode=1)
386
 
 
387
 
        # check for conflict notification
388
 
        self.assertContainsString(err,
389
 
                                  ' M  hello\nText conflict in hello\n1 conflicts encountered.\n')
390
 
        
391
 
        self.assertEqualDiff('<<<<<<< TREE\n'
392
 
                             'fie||||||| BASE-REVISION\n'
393
 
                             'foo=======\n'
394
 
                             'fee>>>>>>> MERGE-SOURCE\n',
395
 
                             open('hello').read())
396
 
 
397
 
    def test_update_checkout_prevent_double_merge(self):
398
 
        """"Launchpad bug 113809 in bzr "update performs two merges"
399
 
        https://launchpad.net/bugs/113809"""
400
 
        master = self.make_branch_and_tree('master')
401
 
        self.build_tree_contents([('master/file', 'initial contents\n')])
402
 
        master.add(['file'])
403
 
        master.commit('one', rev_id='m1')
404
 
 
405
 
        checkout = master.branch.create_checkout('checkout')
406
 
        lightweight = checkout.branch.create_checkout('lightweight',
407
 
                                                      lightweight=True)
408
 
 
409
 
        # time to create a mess
410
 
        # add a commit to the master
411
 
        self.build_tree_contents([('master/file', 'master\n')])
412
 
        master.commit('two', rev_id='m2')
413
 
        self.build_tree_contents([('master/file', 'master local changes\n')])
414
 
 
415
 
        # local commit on the checkout
416
 
        self.build_tree_contents([('checkout/file', 'checkout\n')])
417
 
        checkout.commit('tree', rev_id='c2', local=True)
418
 
        self.build_tree_contents([('checkout/file',
419
 
                                   'checkout local changes\n')])
420
 
 
421
 
        # lightweight 
422
 
        self.build_tree_contents([('lightweight/file',
423
 
                                   'lightweight local changes\n')])
424
 
 
425
 
        # now update (and get conflicts)
426
 
        out, err = self.run_bzr('update lightweight', retcode=1)
427
 
        self.assertEqual('', out)
428
 
        # NB: these conflicts are actually in the source code
429
 
        self.assertFileEqual('''\
430
 
<<<<<<< TREE
431
 
lightweight local changes
432
 
=======
433
 
checkout
434
 
>>>>>>> MERGE-SOURCE
435
 
''',
436
 
                             'lightweight/file')
437
 
 
438
 
        # resolve it
439
 
        self.build_tree_contents([('lightweight/file',
440
 
                                   'lightweight+checkout\n')])
441
 
        self.run_bzr('resolve lightweight/file')
442
 
 
443
 
        # check we get the second conflict
444
 
        out, err = self.run_bzr('update lightweight', retcode=1)
445
 
        self.assertEqual('', out)
446
 
        # NB: these conflicts are actually in the source code
447
 
        self.assertFileEqual('''\
448
 
<<<<<<< TREE
449
 
lightweight+checkout
450
 
=======
451
 
master
452
 
>>>>>>> MERGE-SOURCE
453
 
''',
454
 
                             'lightweight/file')
455
 
 
456
 
 
457
 
    def test_no_upgrade_single_file(self):
458
 
        """There's one basis revision per tree.
459
 
 
460
 
        Since you can't actually change the basis for a single file at the
461
 
        moment, we don't let you think you can.
462
 
 
463
 
        See bug 557886.
464
 
        """
465
 
        self.make_branch_and_tree('.')
466
 
        self.build_tree_contents([('a/',),
467
 
            ('a/file', 'content')])
468
 
        sr = ScriptRunner()
469
 
        sr.run_script(self, '''
470
 
            $ bzr update ./a
471
 
            2>bzr: ERROR: bzr update can only update a whole tree, not a file or subdirectory
472
 
            $ bzr update ./a/file
473
 
            2>bzr: ERROR: bzr update can only update a whole tree, not a file or subdirectory
474
 
            $ bzr update .
475
 
            2>Tree is up to date at revision 0 of branch ...
476
 
            $ cd a
477
 
            $ bzr update .
478
 
            2>bzr: ERROR: bzr update can only update a whole tree, not a file or subdirectory
479
 
            # however, you can update the whole tree from a subdirectory
480
 
            $ bzr update
481
 
            2>Tree is up to date at revision 0 of branch ...
482
 
            ''')
 
208
        self.runbzr(['update', 'checkout'])