35
31
def test_init_with_format(self):
36
32
# Verify bzr init --format constructs something plausible
37
33
t = self.get_transport()
38
self.run_bzr('init --format default')
34
self.runbzr('init --format default')
39
35
self.assertIsDirectory('.bzr', t)
40
36
self.assertIsDirectory('.bzr/checkout', t)
41
37
self.assertIsDirectory('.bzr/checkout/lock', t)
43
39
def test_init_weave(self):
44
40
# --format=weave should be accepted to allow interoperation with
45
41
# old releases when desired.
46
out, err = self.run_bzr('init --format=weave')
42
out, err = self.run_bzr('init', '--format=weave')
47
43
self.assertEqual('', out)
48
44
self.assertEqual('', err)
56
52
newdir = format.initialize(t.abspath('repo'))
57
53
repo = newdir.create_repository(shared=True)
58
54
repo.set_make_working_trees(False)
59
out, err = self.run_bzr('init repo')
55
out, err = self.run_bzr('init', 'repo')
60
56
self.assertEqual('', out)
61
57
self.assertEqual('', err)
62
58
newdir.open_branch()
68
64
self.assertEqual('', err)
70
66
# Can it handle subdirectories of branches too ?
71
out, err = self.run_bzr('init subdir1')
67
out, err = self.run_bzr('init', 'subdir1')
72
68
self.assertEqual('', out)
73
69
self.assertEqual('', err)
74
70
WorkingTree.open('subdir1')
76
self.run_bzr_error(['Parent directory of subdir2/nothere does not exist'],
77
'init subdir2/nothere')
78
out, err = self.run_bzr('init subdir2/nothere', retcode=3)
72
out, err = self.run_bzr('init', 'subdir2/nothere', retcode=3)
79
73
self.assertEqual('', out)
74
self.assertContainsRe(err,
76
'\[Errno 2\] No such file or directory: ')
81
78
os.mkdir('subdir2')
82
out, err = self.run_bzr('init subdir2')
79
out, err = self.run_bzr('init', 'subdir2')
83
80
self.assertEqual('', out)
84
81
self.assertEqual('', err)
85
82
# init an existing branch.
86
out, err = self.run_bzr('init subdir2', retcode=3)
83
out, err = self.run_bzr('init', 'subdir2', retcode=3)
87
84
self.assertEqual('', out)
88
85
self.failUnless(err.startswith('bzr: ERROR: Already a branch:'))
97
94
def test_init_existing_without_workingtree(self):
98
95
# make a repository
99
repo = self.make_repository('.', shared=True)
100
repo.set_make_working_trees(False)
96
self.run_bzr('init-repo', '.')
101
97
# make a branch; by default without a working tree
102
self.run_bzr('init subdir')
98
self.run_bzr('init', 'subdir')
104
out, err = self.run_bzr('init subdir', retcode=3)
100
out, err = self.run_bzr('init', 'subdir', retcode=3)
105
101
# suggests using checkout
106
self.assertContainsRe(err,
107
'ontains a branch.*but no working tree.*checkout')
102
self.assertContainsRe(err, 'ontains a branch.*but no working tree.*checkout')
109
104
def test_no_defaults(self):
110
105
"""Init creates no default ignore rules."""
111
106
self.run_bzr('init')
112
107
self.assertFalse(os.path.exists('.bzrignore'))
114
def test_init_unicode(self):
115
# Make sure getcwd can handle unicode filenames
119
raise TestSkipped("Unable to create Unicode filename")
120
# try to init unicode dir
121
self.run_bzr(['init', u'mu-\xb5'])
123
def create_simple_tree(self):
124
tree = self.make_branch_and_tree('tree')
125
self.build_tree(['tree/a'])
126
tree.add(['a'], ['a-id'])
127
tree.commit('one', rev_id='r1')
130
def test_init_create_prefix(self):
131
"""'bzr init --create-prefix; will create leading directories."""
132
tree = self.create_simple_tree()
134
self.run_bzr_error(['Parent directory of ../new/tree does not exist'],
135
'init ../new/tree', working_dir='tree')
136
self.run_bzr('init ../new/tree --create-prefix', working_dir='tree')
137
self.failUnlessExists('new/tree/.bzr')
140
110
class TestSFTPInit(TestCaseWithSFTPServer):
142
112
def test_init(self):
143
113
# init on a remote url should succeed.
144
out, err = self.run_bzr(['init', self.get_url()])
114
out, err = self.run_bzr('init', self.get_url())
145
115
self.assertEqual('', out)
146
116
self.assertEqual('', err)
150
120
self.make_branch('.')
152
122
# rely on SFTPServer get_url() pointing at '.'
153
out, err = self.run_bzr_error(['Already a branch'],
154
['init', self.get_url()])
123
out, err = self.run_bzr_error(['Already a branch'], 'init', self.get_url())
156
125
# make sure using 'bzr checkout' is not suggested
157
126
# for remote locations missing a working tree
158
self.assertFalse(re.search(r'use bzr checkout', err))
127
self.assertFalse(re.search(r'checkout', err))
160
129
def test_init_existing_branch_with_workingtree(self):
161
130
# don't distinguish between the branch having a working tree or not
163
132
self.make_branch_and_tree('.')
165
134
# rely on SFTPServer get_url() pointing at '.'
166
self.run_bzr_error(['Already a branch'], ['init', self.get_url()])
168
def test_init_append_revisions_only(self):
169
self.run_bzr('init --dirstate-tags normal_branch6')
170
branch = _mod_branch.Branch.open('normal_branch6')
171
self.assertEqual(False, branch._get_append_revisions_only())
172
self.run_bzr('init --append-revisions-only --dirstate-tags branch6')
173
branch = _mod_branch.Branch.open('branch6')
174
self.assertEqual(True, branch._get_append_revisions_only())
175
self.run_bzr_error(['cannot be set to append-revisions-only'],
176
'init --append-revisions-only --knit knit')
135
self.run_bzr_error(['Already a branch'], 'init', self.get_url())