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
24
branch as _mod_branch,
25
config as _mod_config,
23
29
from bzrlib.bzrdir import BzrDirMetaFormat1
24
from bzrlib.tests.blackbox import ExternalBase
30
from bzrlib.tests import TestSkipped
31
from bzrlib.tests import TestCaseWithTransport
25
32
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
26
33
from bzrlib.workingtree import WorkingTree
29
class TestInit(ExternalBase):
36
class TestInit(TestCaseWithTransport):
39
TestCaseWithTransport.setUp(self)
40
self._default_label = '2a'
31
42
def test_init_with_format(self):
32
43
# Verify bzr init --format constructs something plausible
33
44
t = self.get_transport()
34
self.runbzr('init --format default')
45
self.run_bzr('init --format default')
35
46
self.assertIsDirectory('.bzr', t)
36
47
self.assertIsDirectory('.bzr/checkout', t)
37
48
self.assertIsDirectory('.bzr/checkout/lock', t)
39
def test_init_weave(self):
40
# --format=weave should be accepted to allow interoperation with
41
# old releases when desired.
42
out, err = self.run_bzr('init', '--format=weave')
43
self.assertEqual('', out)
50
def test_init_format_2a(self):
51
"""Smoke test for constructing a format 2a repoistory."""
52
out, err = self.run_bzr('init --format=2a')
53
self.assertEqual("""Created a standalone tree (format: 2a)\n""",
44
55
self.assertEqual('', err)
46
57
def test_init_at_repository_root(self):
52
63
newdir = format.initialize(t.abspath('repo'))
53
64
repo = newdir.create_repository(shared=True)
54
65
repo.set_make_working_trees(False)
55
out, err = self.run_bzr('init', 'repo')
56
self.assertEqual('', out)
66
out, err = self.run_bzr('init repo')
67
self.assertEqual("""Created a repository tree (format: %s)
68
Using shared repository: %s
69
""" % (self._default_label, urlutils.local_path_from_url(
70
repo.bzrdir.root_transport.external_url())), out)
71
cwd = osutils.getcwd()
72
self.assertEndsWith(out, cwd + '/repo/\n')
57
73
self.assertEqual('', err)
58
74
newdir.open_branch()
59
75
newdir.open_workingtree()
61
77
def test_init_branch(self):
62
78
out, err = self.run_bzr('init')
63
self.assertEqual('', out)
79
self.assertEqual("Created a standalone tree (format: %s)\n" % (
80
self._default_label,), out)
64
81
self.assertEqual('', err)
66
83
# Can it handle subdirectories of branches too ?
67
out, err = self.run_bzr('init', 'subdir1')
68
self.assertEqual('', out)
84
out, err = self.run_bzr('init subdir1')
85
self.assertEqual("Created a standalone tree (format: %s)\n" % (
86
self._default_label,), out)
69
87
self.assertEqual('', err)
70
88
WorkingTree.open('subdir1')
72
out, err = self.run_bzr('init', 'subdir2/nothere', retcode=3)
90
self.run_bzr_error(['Parent directory of subdir2/nothere does not exist'],
91
'init subdir2/nothere')
92
out, err = self.run_bzr('init subdir2/nothere', retcode=3)
73
93
self.assertEqual('', out)
74
self.assertContainsRe(err,
76
'\[Errno 2\] No such file or directory: ')
78
95
os.mkdir('subdir2')
79
out, err = self.run_bzr('init', 'subdir2')
80
self.assertEqual('', out)
96
out, err = self.run_bzr('init subdir2')
97
self.assertEqual("Created a standalone tree (format: %s)\n" % (
98
self._default_label,), out)
81
99
self.assertEqual('', err)
82
100
# init an existing branch.
83
out, err = self.run_bzr('init', 'subdir2', retcode=3)
84
self.assertEqual('', out)
85
self.failUnless(err.startswith('bzr: ERROR: Already a branch:'))
101
out, err = self.run_bzr('init subdir2', retcode=3)
102
self.assertEqual('', out)
103
self.assertTrue(err.startswith('bzr: ERROR: Already a branch:'))
105
def test_init_branch_quiet(self):
106
out, err = self.run_bzr('init -q')
107
self.assertEqual('', out)
108
self.assertEqual('', err)
87
110
def test_init_existing_branch(self):
88
111
self.run_bzr('init')
94
117
def test_init_existing_without_workingtree(self):
95
118
# make a repository
96
self.run_bzr('init-repo', '.')
119
repo = self.make_repository('.', shared=True)
120
repo.set_make_working_trees(False)
97
121
# make a branch; by default without a working tree
98
self.run_bzr('init', 'subdir')
122
self.run_bzr('init subdir')
100
out, err = self.run_bzr('init', 'subdir', retcode=3)
124
out, err = self.run_bzr('init subdir', retcode=3)
101
125
# suggests using checkout
102
self.assertContainsRe(err, 'ontains a branch.*but no working tree.*checkout')
126
self.assertContainsRe(err,
127
'ontains a branch.*but no working tree.*checkout')
104
129
def test_no_defaults(self):
105
130
"""Init creates no default ignore rules."""
106
131
self.run_bzr('init')
107
132
self.assertFalse(os.path.exists('.bzrignore'))
134
def test_init_unicode(self):
135
# Make sure getcwd can handle unicode filenames
139
raise TestSkipped("Unable to create Unicode filename")
140
# try to init unicode dir
141
self.run_bzr(['init', '-q', u'mu-\xb5'])
143
def create_simple_tree(self):
144
tree = self.make_branch_and_tree('tree')
145
self.build_tree(['tree/a'])
146
tree.add(['a'], ['a-id'])
147
tree.commit('one', rev_id='r1')
150
def test_init_create_prefix(self):
151
"""'bzr init --create-prefix; will create leading directories."""
152
tree = self.create_simple_tree()
154
self.run_bzr_error(['Parent directory of ../new/tree does not exist'],
155
'init ../new/tree', working_dir='tree')
156
self.run_bzr('init ../new/tree --create-prefix', working_dir='tree')
157
self.assertPathExists('new/tree/.bzr')
159
def test_init_default_format_option(self):
160
"""bzr init should read default format from option default_format"""
161
conf = _mod_config.GlobalConfig.from_string('''
165
out, err = self.run_bzr_subprocess('init')
166
self.assertContainsRe(out, '1.9')
168
def test_init_no_tree(self):
169
"""'bzr init --no-tree' creates a branch with no working tree."""
170
out, err = self.run_bzr('init --no-tree')
171
self.assertStartsWith(out, 'Created a standalone branch')
110
174
class TestSFTPInit(TestCaseWithSFTPServer):
112
176
def test_init(self):
113
177
# init on a remote url should succeed.
114
out, err = self.run_bzr('init', self.get_url())
115
self.assertEqual('', out)
178
out, err = self.run_bzr(['init', '--pack-0.92', self.get_url()])
179
self.assertEqual(out,
180
"""Created a standalone branch (format: pack-0.92)\n""")
116
181
self.assertEqual('', err)
118
183
def test_init_existing_branch(self):
119
184
# when there is already a branch present, make mention
120
185
self.make_branch('.')
122
187
# rely on SFTPServer get_url() pointing at '.'
123
out, err = self.run_bzr_error(['Already a branch'], 'init', self.get_url())
188
out, err = self.run_bzr_error(['Already a branch'],
189
['init', self.get_url()])
125
191
# make sure using 'bzr checkout' is not suggested
126
192
# for remote locations missing a working tree
127
self.assertFalse(re.search(r'checkout', err))
193
self.assertFalse(re.search(r'use bzr checkout', err))
129
195
def test_init_existing_branch_with_workingtree(self):
130
196
# don't distinguish between the branch having a working tree or not
132
198
self.make_branch_and_tree('.')
134
200
# rely on SFTPServer get_url() pointing at '.'
135
self.run_bzr_error(['Already a branch'], 'init', self.get_url())
201
self.run_bzr_error(['Already a branch'], ['init', self.get_url()])
203
def test_init_append_revisions_only(self):
204
self.run_bzr('init --dirstate-tags normal_branch6')
205
branch = _mod_branch.Branch.open('normal_branch6')
206
self.assertEqual(None, branch._get_append_revisions_only())
207
self.run_bzr('init --append-revisions-only --dirstate-tags branch6')
208
branch = _mod_branch.Branch.open('branch6')
209
self.assertEqual(True, branch._get_append_revisions_only())
210
self.run_bzr_error(['cannot be set to append-revisions-only'],
211
'init --append-revisions-only --knit knit')
213
def test_init_without_username(self):
214
"""Ensure init works if username is not set.
216
# bzr makes user specified whoami mandatory for operations
217
# like commit as whoami is recorded. init however is not so final
218
# and uses whoami only in a lock file. Without whoami the login name
219
# is used. This test is to ensure that init passes even when whoami
221
self.overrideEnv('EMAIL', None)
222
self.overrideEnv('BZR_EMAIL', None)
223
out, err = self.run_bzr(['init', 'foo'])
224
self.assertEqual(err, '')
225
self.assertTrue(os.path.exists('foo'))