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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
17
"""Tests for the 'checkout' CLI command."""
25
import bzrlib.bzrdir as bzrdir
26
import bzrlib.errors as errors
27
from bzrlib.tests.blackbox import ExternalBase
26
branch as _mod_branch,
31
from bzrlib.tests.blackbox import (
34
from bzrlib.tests import (
30
40
class TestCheckout(ExternalBase):
33
43
super(TestCheckout, self).setUp()
34
44
tree = bzrdir.BzrDir.create_standalone_workingtree('branch')
38
48
tree.commit('2', rev_id='2')
40
50
def test_checkout_makes_bound_branch(self):
41
self.runbzr('checkout branch checkout')
51
self.run_bzr('checkout branch checkout')
42
52
# if we have a checkout, the branch base should be 'branch'
43
53
source = bzrdir.BzrDir.open('branch')
44
54
result = bzrdir.BzrDir.open('checkout')
80
90
format=bzrdir.BzrDirMetaFormat1())
81
91
# check no tree was created
82
92
self.assertRaises(errors.NoWorkingTree, branch.bzrdir.open_workingtree)
83
out, err = self.run_bzr('checkout', 'treeless-branch')
93
out, err = self.run_bzr('checkout treeless-branch')
84
94
# we should have a tree now
85
95
branch.bzrdir.open_workingtree()
87
out, err = self.run_bzr('diff', 'treeless-branch')
97
out, err = self.run_bzr('diff treeless-branch')
89
99
# now test with no parameters
90
100
branch = bzrdir.BzrDir.create_branch_convenience(
98
108
branch.bzrdir.open_workingtree()
100
110
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)