1
# Copyright (C) 2006, 2007, 2009, 2010 Canonical Ltd
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
# GNU General Public License for more details.
13
# You should have received a copy of the GNU General Public License
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
17
"""Tests for the 'checkout' CLI command."""
19
from cStringIO import StringIO
26
branch as _mod_branch,
31
from bzrlib.tests.blackbox import (
34
from bzrlib.tests import (
40
class TestCheckout(ExternalBase):
43
super(TestCheckout, self).setUp()
44
tree = bzrdir.BzrDir.create_standalone_workingtree('branch')
45
tree.commit('1', rev_id='1', allow_pointless=True)
46
self.build_tree(['branch/added_in_2'])
47
tree.add('added_in_2')
48
tree.commit('2', rev_id='2')
50
def test_checkout_makes_bound_branch(self):
51
self.run_bzr('checkout branch checkout')
52
# if we have a checkout, the branch base should be 'branch'
53
source = bzrdir.BzrDir.open('branch')
54
result = bzrdir.BzrDir.open('checkout')
55
self.assertEqual(source.open_branch().bzrdir.root_transport.base,
56
result.open_branch().get_bound_location())
58
def test_checkout_light_makes_checkout(self):
59
self.run_bzr('checkout --lightweight branch checkout')
60
# if we have a checkout, the branch base should be 'branch'
61
source = bzrdir.BzrDir.open('branch')
62
result = bzrdir.BzrDir.open('checkout')
63
self.assertEqual(source.open_branch().bzrdir.root_transport.base,
64
result.open_branch().bzrdir.root_transport.base)
66
def test_checkout_dash_r(self):
67
out, err = self.run_bzr(['checkout', '-r', '-2', 'branch', 'checkout'])
68
self.assertContainsRe(out, 'Copying history to "checkout".')
69
# the working tree should now be at revision '1' with the content
71
result = bzrdir.BzrDir.open('checkout')
72
self.assertEqual(['1'], result.open_workingtree().get_parent_ids())
73
self.failIfExists('checkout/added_in_2')
75
def test_checkout_light_dash_r(self):
76
out, err = self.run_bzr(['checkout','--lightweight', '-r', '-2',
77
'branch', 'checkout'])
78
self.assertNotContainsRe(out, 'Copying history')
79
# the working tree should now be at revision '1' with the content
81
result = bzrdir.BzrDir.open('checkout')
82
self.assertEqual(['1'], result.open_workingtree().get_parent_ids())
83
self.failIfExists('checkout/added_in_2')
85
def test_checkout_reconstitutes_working_trees(self):
86
# doing a 'bzr checkout' in the directory of a branch with no tree
87
# or a 'bzr checkout path' with path the name of a directory with
88
# a branch with no tree will reconsistute the tree.
89
os.mkdir('treeless-branch')
90
branch = bzrdir.BzrDir.create_branch_convenience(
93
format=bzrdir.BzrDirMetaFormat1())
94
# check no tree was created
95
self.assertRaises(errors.NoWorkingTree, branch.bzrdir.open_workingtree)
96
out, err = self.run_bzr('checkout treeless-branch')
97
# we should have a tree now
98
branch.bzrdir.open_workingtree()
100
out, err = self.run_bzr('diff treeless-branch')
102
# now test with no parameters
103
branch = bzrdir.BzrDir.create_branch_convenience(
105
force_new_tree=False,
106
format=bzrdir.BzrDirMetaFormat1())
107
# check no tree was created
108
self.assertRaises(errors.NoWorkingTree, branch.bzrdir.open_workingtree)
109
out, err = self.run_bzr('checkout')
110
# we should have a tree now
111
branch.bzrdir.open_workingtree()
113
out, err = self.run_bzr('diff')
115
def _test_checkout_existing_dir(self, lightweight):
116
source = self.make_branch_and_tree('source')
117
self.build_tree_contents([('source/file1', 'content1'),
118
('source/file2', 'content2'),])
119
source.add(['file1', 'file2'])
120
source.commit('added files')
121
self.build_tree_contents([('target/', ''),
122
('target/file1', 'content1'),
123
('target/file2', 'content3'),])
124
cmd = ['checkout', 'source', 'target']
126
cmd.append('--lightweight')
127
self.run_bzr('checkout source target')
128
# files with unique content should be moved
129
self.failUnlessExists('target/file2.moved')
130
# files with content matching tree should not be moved
131
self.failIfExists('target/file1.moved')
133
def test_checkout_existing_dir_heavy(self):
134
self._test_checkout_existing_dir(False)
136
def test_checkout_existing_dir_lightweight(self):
137
self._test_checkout_existing_dir(True)
139
def test_checkout_in_branch_with_r(self):
140
branch = _mod_branch.Branch.open('branch')
141
branch.bzrdir.destroy_workingtree()
143
self.run_bzr('checkout -r 1')
144
tree = workingtree.WorkingTree.open('.')
145
self.assertEqual('1', tree.last_revision())
146
branch.bzrdir.destroy_workingtree()
147
self.run_bzr('checkout -r 0')
148
self.assertEqual('null:', tree.last_revision())
150
def test_checkout_files_from(self):
151
branch = _mod_branch.Branch.open('branch')
152
self.run_bzr(['checkout', 'branch', 'branch2', '--files-from',
155
def test_checkout_hardlink(self):
156
self.requireFeature(HardlinkFeature)
157
source = self.make_branch_and_tree('source')
158
self.build_tree(['source/file1'])
160
source.commit('added file')
161
out, err = self.run_bzr(['checkout', 'source', 'target',
162
'--files-from', 'source',
164
source_stat = os.stat('source/file1')
165
target_stat = os.stat('target/file1')
166
self.assertEqual(source_stat, target_stat)