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')
90
80
format=bzrdir.BzrDirMetaFormat1())
91
81
# check no tree was created
92
82
self.assertRaises(errors.NoWorkingTree, branch.bzrdir.open_workingtree)
93
out, err = self.run_bzr('checkout treeless-branch')
83
out, err = self.run_bzr('checkout', 'treeless-branch')
94
84
# we should have a tree now
95
85
branch.bzrdir.open_workingtree()
97
out, err = self.run_bzr('diff treeless-branch')
87
out, err = self.run_bzr('diff', 'treeless-branch')
99
89
# now test with no parameters
100
90
branch = bzrdir.BzrDir.create_branch_convenience(
108
98
branch.bzrdir.open_workingtree()
110
100
out, err = self.run_bzr('diff')
112
def _test_checkout_existing_dir(self, lightweight):
113
source = self.make_branch_and_tree('source')
114
self.build_tree_contents([('source/file1', 'content1'),
115
('source/file2', 'content2'),])
116
source.add(['file1', 'file2'])
117
source.commit('added files')
118
self.build_tree_contents([('target/', ''),
119
('target/file1', 'content1'),
120
('target/file2', 'content3'),])
121
cmd = ['checkout', 'source', 'target']
123
cmd.append('--lightweight')
124
self.run_bzr('checkout source target')
125
# files with unique content should be moved
126
self.failUnlessExists('target/file2.moved')
127
# files with content matching tree should not be moved
128
self.failIfExists('target/file1.moved')
130
def test_checkout_existing_dir_heavy(self):
131
self._test_checkout_existing_dir(False)
133
def test_checkout_existing_dir_lightweight(self):
134
self._test_checkout_existing_dir(True)
136
def test_checkout_in_branch_with_r(self):
137
branch = _mod_branch.Branch.open('branch')
138
branch.bzrdir.destroy_workingtree()
140
self.run_bzr('checkout -r 1')
141
tree = workingtree.WorkingTree.open('.')
142
self.assertEqual('1', tree.last_revision())
143
branch.bzrdir.destroy_workingtree()
144
self.run_bzr('checkout -r 0')
145
self.assertEqual('null:', tree.last_revision())
147
def test_checkout_files_from(self):
148
branch = _mod_branch.Branch.open('branch')
149
self.run_bzr(['checkout', 'branch', 'branch2', '--files-from',
152
def test_checkout_hardlink(self):
153
self.requireFeature(HardlinkFeature)
154
source = self.make_branch_and_tree('source')
155
self.build_tree(['source/file1'])
157
source.commit('added file')
158
out, err = self.run_bzr(['checkout', 'source', 'target',
159
'--files-from', 'source',
161
source_stat = os.stat('source/file1')
162
target_stat = os.stat('target/file1')
163
self.assertEqual(source_stat, target_stat)