~bzr-pqm/bzr/bzr.dev

5557.1.7 by John Arbash Meinel
Merge in the bzr.dev 5582
1
# Copyright (C) 2006-2011 Canonical Ltd
1887.1.1 by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines,
2
#
1553.5.78 by Martin Pool
New bzr init --format option and test
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
1887.1.1 by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines,
7
#
1553.5.78 by Martin Pool
New bzr init --format option and test
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
1887.1.1 by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines,
12
#
1553.5.78 by Martin Pool
New bzr init --format option and test
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
4183.7.1 by Sabin Iacob
update FSF mailing address
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
1553.5.78 by Martin Pool
New bzr init --format option and test
16
17
5448.6.6 by Matthew Gordon
Added test for 'bzr init --no-tree'
18
"""Test 'bzr init'"""
1553.5.78 by Martin Pool
New bzr init --format option and test
19
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
20
import os
1662.1.19 by Martin Pool
Better error message when initting existing tree
21
import re
1553.5.78 by Martin Pool
New bzr init --format option and test
22
2230.3.42 by Aaron Bentley
add --append-revisions-only option to init
23
from bzrlib import (
24
    branch as _mod_branch,
5448.4.2 by Neil Martinsen-Burrell
blackbox test
25
    config as _mod_config,
4789.8.1 by John Arbash Meinel
Don't make explicit assumptions about testing current working dir.
26
    osutils,
3922.2.1 by Marius Kruger
make `bzr init` less verbose, and update tests
27
    urlutils,
2230.3.42 by Aaron Bentley
add --append-revisions-only option to init
28
    )
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
29
from bzrlib.bzrdir import BzrDirMetaFormat1
2294.2.1 by Alexander Belchenko
Bugfix #85599: ``bzr init`` works with unicode argument LOCATION
30
from bzrlib.tests import TestSkipped
5283.4.5 by Martin Pool
Update remaining subclasses of ExternalBase
31
from bzrlib.tests import TestCaseWithTransport
1830.4.1 by Wouter van Heyst
Allow bzr init to create remote branches
32
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
33
from bzrlib.workingtree import WorkingTree
1553.5.78 by Martin Pool
New bzr init --format option and test
34
35
5283.4.5 by Martin Pool
Update remaining subclasses of ExternalBase
36
class TestInit(TestCaseWithTransport):
1553.5.78 by Martin Pool
New bzr init --format option and test
37
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
38
    def setUp(self):
5283.4.5 by Martin Pool
Update remaining subclasses of ExternalBase
39
        TestCaseWithTransport.setUp(self)
4599.4.5 by Robert Collins
Blackbox init tests 2a ready.
40
        self._default_label = '2a'
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
41
1553.5.78 by Martin Pool
New bzr init --format option and test
42
    def test_init_with_format(self):
1666.1.3 by Robert Collins
Fix and test upgrades from bzrdir 6 over SFTP.
43
        # Verify bzr init --format constructs something plausible
1553.5.78 by Martin Pool
New bzr init --format option and test
44
        t = self.get_transport()
2530.3.1 by Martin Pool
Cleanup old variations on run_bzr in the test suite
45
        self.run_bzr('init --format default')
1553.5.78 by Martin Pool
New bzr init --format option and test
46
        self.assertIsDirectory('.bzr', t)
47
        self.assertIsDirectory('.bzr/checkout', t)
48
        self.assertIsDirectory('.bzr/checkout/lock', t)
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
49
4428.2.1 by Martin Pool
Add 2a format
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""",
54
            out)
55
        self.assertEqual('', err)
56
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
57
    def test_init_at_repository_root(self):
58
        # bzr init at the root of a repository should create a branch
59
        # and working tree even when creation of working trees is disabled.
60
        t = self.get_transport()
61
        t.mkdir('repo')
62
        format = BzrDirMetaFormat1()
63
        newdir = format.initialize(t.abspath('repo'))
64
        repo = newdir.create_repository(shared=True)
65
        repo.set_make_working_trees(False)
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
66
        out, err = self.run_bzr('init repo')
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
67
        self.assertEqual("""Created a repository tree (format: %s)
3922.2.1 by Marius Kruger
make `bzr init` less verbose, and update tests
68
Using shared repository: %s
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
69
""" % (self._default_label, urlutils.local_path_from_url(
70
            repo.bzrdir.root_transport.external_url())), out)
4789.8.1 by John Arbash Meinel
Don't make explicit assumptions about testing current working dir.
71
        cwd = osutils.getcwd()
72
        self.assertEndsWith(out, cwd + '/repo/\n')
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
73
        self.assertEqual('', err)
74
        newdir.open_branch()
75
        newdir.open_workingtree()
3922.2.1 by Marius Kruger
make `bzr init` less verbose, and update tests
76
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
77
    def test_init_branch(self):
78
        out, err = self.run_bzr('init')
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
79
        self.assertEqual("Created a standalone tree (format: %s)\n" % (
80
            self._default_label,), out)
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
81
        self.assertEqual('', err)
82
83
        # Can it handle subdirectories of branches too ?
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
84
        out, err = self.run_bzr('init subdir1')
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
85
        self.assertEqual("Created a standalone tree (format: %s)\n" % (
86
            self._default_label,), out)
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
87
        self.assertEqual('', err)
88
        WorkingTree.open('subdir1')
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
89
2524.1.1 by Aaron Bentley
Revert broken changes
90
        self.run_bzr_error(['Parent directory of subdir2/nothere does not exist'],
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
91
                            'init subdir2/nothere')
92
        out, err = self.run_bzr('init subdir2/nothere', retcode=3)
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
93
        self.assertEqual('', out)
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
94
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
95
        os.mkdir('subdir2')
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
96
        out, err = self.run_bzr('init subdir2')
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
97
        self.assertEqual("Created a standalone tree (format: %s)\n" % (
98
            self._default_label,), out)
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
99
        self.assertEqual('', err)
100
        # init an existing branch.
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
101
        out, err = self.run_bzr('init subdir2', retcode=3)
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
102
        self.assertEqual('', out)
5784.1.1 by Martin Pool
Stop using failIf, failUnless, etc
103
        self.assertTrue(err.startswith('bzr: ERROR: Already a branch:'))
1662.1.19 by Martin Pool
Better error message when initting existing tree
104
3535.9.6 by Marius Kruger
add explicit blackbox tests for 'init -q' and 'init-repo -q'
105
    def test_init_branch_quiet(self):
106
        out, err = self.run_bzr('init -q')
107
        self.assertEqual('', out)
108
        self.assertEqual('', err)
109
1662.1.19 by Martin Pool
Better error message when initting existing tree
110
    def test_init_existing_branch(self):
111
        self.run_bzr('init')
112
        out, err = self.run_bzr('init', retcode=3)
113
        self.assertContainsRe(err, 'Already a branch')
114
        # don't suggest making a checkout, there's already a working tree
115
        self.assertFalse(re.search(r'checkout', err))
116
117
    def test_init_existing_without_workingtree(self):
118
        # make a repository
2257.2.1 by Wouter van Heyst
Change the ui level default for init-repo to --trees.
119
        repo = self.make_repository('.', shared=True)
120
        repo.set_make_working_trees(False)
1662.1.19 by Martin Pool
Better error message when initting existing tree
121
        # make a branch; by default without a working tree
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
122
        self.run_bzr('init subdir')
1662.1.19 by Martin Pool
Better error message when initting existing tree
123
        # fail
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
124
        out, err = self.run_bzr('init subdir', retcode=3)
1662.1.19 by Martin Pool
Better error message when initting existing tree
125
        # suggests using checkout
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
126
        self.assertContainsRe(err,
127
                              'ontains a branch.*but no working tree.*checkout')
1662.1.19 by Martin Pool
Better error message when initting existing tree
128
1765.1.1 by Robert Collins
Remove the default ignores list from bzr, lowering the minimum overhead in bzr add.
129
    def test_no_defaults(self):
130
        """Init creates no default ignore rules."""
131
        self.run_bzr('init')
132
        self.assertFalse(os.path.exists('.bzrignore'))
1830.4.1 by Wouter van Heyst
Allow bzr init to create remote branches
133
2294.2.1 by Alexander Belchenko
Bugfix #85599: ``bzr init`` works with unicode argument LOCATION
134
    def test_init_unicode(self):
135
        # Make sure getcwd can handle unicode filenames
136
        try:
137
            os.mkdir(u'mu-\xb5')
138
        except UnicodeError:
139
            raise TestSkipped("Unable to create Unicode filename")
140
        # try to init unicode dir
3697.5.4 by John Arbash Meinel
Merge vila's init[-repo] changes and add a NEWS entry.
141
        self.run_bzr(['init', '-q', u'mu-\xb5'])
2294.2.1 by Alexander Belchenko
Bugfix #85599: ``bzr init`` works with unicode argument LOCATION
142
2524.1.1 by Aaron Bentley
Revert broken changes
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')
148
        return tree
149
150
    def test_init_create_prefix(self):
151
        """'bzr init --create-prefix; will create leading directories."""
152
        tree = self.create_simple_tree()
153
154
        self.run_bzr_error(['Parent directory of ../new/tree does not exist'],
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
155
                            'init ../new/tree', working_dir='tree')
156
        self.run_bzr('init ../new/tree --create-prefix', working_dir='tree')
5784.1.3 by Martin Pool
Switch away from using failUnlessExists and failIfExists
157
        self.assertPathExists('new/tree/.bzr')
2524.1.1 by Aaron Bentley
Revert broken changes
158
5448.4.2 by Neil Martinsen-Burrell
blackbox test
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('''
162
[DEFAULT]
163
default_format = 1.9
164
''', save=True)
5448.4.3 by Neil Martinsen-Burrell
use option along with controldir.set_default to control the default format
165
        out, err = self.run_bzr_subprocess('init')
5448.4.2 by Neil Martinsen-Burrell
blackbox test
166
        self.assertContainsRe(out, '1.9')
167
5448.6.6 by Matthew Gordon
Added test for 'bzr init --no-tree'
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')
172
1830.4.7 by Wouter van Heyst
review fixes, rename transport variable to to_transport
173
1830.4.1 by Wouter van Heyst
Allow bzr init to create remote branches
174
class TestSFTPInit(TestCaseWithSFTPServer):
175
176
    def test_init(self):
1830.4.3 by Wouter van Heyst
more review comments
177
        # init on a remote url should succeed.
4599.1.1 by Robert Collins
Make blackbox init tests able to be trivially changed to 2a.
178
        out, err = self.run_bzr(['init', '--pack-0.92', self.get_url()])
3922.2.1 by Marius Kruger
make `bzr init` less verbose, and update tests
179
        self.assertEqual(out,
180
            """Created a standalone branch (format: pack-0.92)\n""")
1830.4.1 by Wouter van Heyst
Allow bzr init to create remote branches
181
        self.assertEqual('', err)
3922.2.1 by Marius Kruger
make `bzr init` less verbose, and update tests
182
1830.4.3 by Wouter van Heyst
more review comments
183
    def test_init_existing_branch(self):
184
        # when there is already a branch present, make mention
1830.4.4 by Wouter van Heyst
more review comments
185
        self.make_branch('.')
186
187
        # rely on SFTPServer get_url() pointing at '.'
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
188
        out, err = self.run_bzr_error(['Already a branch'],
189
                                      ['init', self.get_url()])
1830.4.5 by Wouter van Heyst
cleanup
190
191
        # make sure using 'bzr checkout' is not suggested
192
        # for remote locations missing a working tree
2264.1.1 by Martin Pool
make TestSFTPInit.test_init_existing_branch less fragile (jamesw)
193
        self.assertFalse(re.search(r'use bzr checkout', err))
1830.4.1 by Wouter van Heyst
Allow bzr init to create remote branches
194
1830.4.4 by Wouter van Heyst
more review comments
195
    def test_init_existing_branch_with_workingtree(self):
1830.4.3 by Wouter van Heyst
more review comments
196
        # don't distinguish between the branch having a working tree or not
197
        # when the branch itself is remote.
198
        self.make_branch_and_tree('.')
199
200
        # rely on SFTPServer get_url() pointing at '.'
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
201
        self.run_bzr_error(['Already a branch'], ['init', self.get_url()])
2230.3.42 by Aaron Bentley
add --append-revisions-only option to init
202
203
    def test_init_append_revisions_only(self):
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
204
        self.run_bzr('init --dirstate-tags normal_branch6')
2230.3.42 by Aaron Bentley
add --append-revisions-only option to init
205
        branch = _mod_branch.Branch.open('normal_branch6')
4989.2.13 by Vincent Ladeuil
append_revisions_only accept all valid booleans, update doc to
206
        self.assertEqual(None, branch._get_append_revisions_only())
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
207
        self.run_bzr('init --append-revisions-only --dirstate-tags branch6')
2230.3.42 by Aaron Bentley
add --append-revisions-only option to init
208
        branch = _mod_branch.Branch.open('branch6')
209
        self.assertEqual(True, branch._get_append_revisions_only())
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
210
        self.run_bzr_error(['cannot be set to append-revisions-only'],
211
                           'init --append-revisions-only --knit knit')
5187.2.4 by Parth Malwankar
added tests.
212
213
    def test_init_without_username(self):
5187.2.6 by Parth Malwankar
lockdir no long mandates whoami but uses unicode version of getuser
214
        """Ensure init works if username is not set.
5187.2.4 by Parth Malwankar
added tests.
215
        """
5187.2.9 by Parth Malwankar
added comment to init/init-repo pass tests for lacking whoami.
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
220
        # is not available.
5570.3.12 by Vincent Ladeuil
Replace osutils.set_or_unset_env calls with self.overrideEnv.
221
        self.overrideEnv('EMAIL', None)
222
        self.overrideEnv('BZR_EMAIL', None)
5187.2.6 by Parth Malwankar
lockdir no long mandates whoami but uses unicode version of getuser
223
        out, err = self.run_bzr(['init', 'foo'])
224
        self.assertEqual(err, '')
225
        self.assertTrue(os.path.exists('foo'))
5570.3.12 by Vincent Ladeuil
Replace osutils.set_or_unset_env calls with self.overrideEnv.
226