1
# Copyright (C) 2005, 2006, 2009 Canonical Ltd
1
# Copyright (C) 2006, 2007, 2009, 2010 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
64
64
result.open_branch().bzrdir.root_transport.base)
66
66
def test_checkout_dash_r(self):
67
self.run_bzr('checkout -r -2 branch checkout')
67
out, err = self.run_bzr(['checkout', '-r', '-2', 'branch', 'checkout'])
68
68
# the working tree should now be at revision '1' with the content
70
70
result = bzrdir.BzrDir.open('checkout')
71
71
self.assertEqual(['1'], result.open_workingtree().get_parent_ids())
72
self.failIfExists('checkout/added_in_2')
72
self.assertPathDoesNotExist('checkout/added_in_2')
74
74
def test_checkout_light_dash_r(self):
75
self.run_bzr('checkout --lightweight -r -2 branch checkout')
75
out, err = self.run_bzr(['checkout','--lightweight', '-r', '-2',
76
'branch', 'checkout'])
76
77
# the working tree should now be at revision '1' with the content
78
79
result = bzrdir.BzrDir.open('checkout')
79
80
self.assertEqual(['1'], result.open_workingtree().get_parent_ids())
80
self.failIfExists('checkout/added_in_2')
81
self.assertPathDoesNotExist('checkout/added_in_2')
82
83
def test_checkout_reconstitutes_working_trees(self):
83
84
# doing a 'bzr checkout' in the directory of a branch with no tree
123
124
cmd.append('--lightweight')
124
125
self.run_bzr('checkout source target')
125
126
# files with unique content should be moved
126
self.failUnlessExists('target/file2.moved')
127
self.assertPathExists('target/file2.moved')
127
128
# files with content matching tree should not be moved
128
self.failIfExists('target/file1.moved')
129
self.assertPathDoesNotExist('target/file1.moved')
130
131
def test_checkout_existing_dir_heavy(self):
131
132
self._test_checkout_existing_dir(False)
155
156
self.build_tree(['source/file1'])
156
157
source.add('file1')
157
158
source.commit('added file')
158
out, err = self.run_bzr(['checkout', 'source', 'target',
159
'--files-from', 'source',
159
out, err = self.run_bzr('checkout source target --hardlink')
161
160
source_stat = os.stat('source/file1')
162
161
target_stat = os.stat('target/file1')
163
162
self.assertEqual(source_stat, target_stat)
164
def test_checkout_hardlink_files_from(self):
165
self.requireFeature(HardlinkFeature)
166
source = self.make_branch_and_tree('source')
167
self.build_tree(['source/file1'])
169
source.commit('added file')
170
source.bzrdir.sprout('second')
171
out, err = self.run_bzr('checkout source target --hardlink'
172
' --files-from second')
173
second_stat = os.stat('second/file1')
174
target_stat = os.stat('target/file1')
175
self.assertEqual(second_stat, target_stat)