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
17
17
"""Tests for the 'checkout' CLI command."""
26
branch as _mod_branch,
31
from bzrlib.tests.blackbox import (
34
from bzrlib.tests import (
25
import bzrlib.bzrdir as bzrdir
26
import bzrlib.errors as errors
27
from bzrlib.tests.blackbox import ExternalBase
40
30
class TestCheckout(ExternalBase):
43
33
super(TestCheckout, self).setUp()
44
34
tree = bzrdir.BzrDir.create_standalone_workingtree('branch')
48
38
tree.commit('2', rev_id='2')
50
40
def test_checkout_makes_bound_branch(self):
51
self.run_bzr('checkout branch checkout')
41
self.runbzr('checkout branch checkout')
52
42
# if we have a checkout, the branch base should be 'branch'
53
43
source = bzrdir.BzrDir.open('branch')
54
44
result = bzrdir.BzrDir.open('checkout')
64
54
result.open_branch().bzrdir.root_transport.base)
66
56
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".')
57
self.runbzr('checkout -r -2 branch checkout')
69
58
# the working tree should now be at revision '1' with the content
71
60
result = bzrdir.BzrDir.open('checkout')
73
62
self.failIfExists('checkout/added_in_2')
75
64
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')
65
self.runbzr('checkout --lightweight -r -2 branch checkout')
79
66
# the working tree should now be at revision '1' with the content
81
68
result = bzrdir.BzrDir.open('checkout')
93
80
format=bzrdir.BzrDirMetaFormat1())
94
81
# check no tree was created
95
82
self.assertRaises(errors.NoWorkingTree, branch.bzrdir.open_workingtree)
96
out, err = self.run_bzr('checkout treeless-branch')
83
out, err = self.run_bzr('checkout', 'treeless-branch')
97
84
# we should have a tree now
98
85
branch.bzrdir.open_workingtree()
100
out, err = self.run_bzr('diff treeless-branch')
87
out, err = self.run_bzr('diff', 'treeless-branch')
102
89
# now test with no parameters
103
90
branch = bzrdir.BzrDir.create_branch_convenience(
111
98
branch.bzrdir.open_workingtree()
113
100
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)