/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_init.py

  • Committer: v.ladeuil+lp at free
  • Date: 2006-10-12 14:29:32 UTC
  • mto: (2145.1.1 keepalive)
  • mto: This revision was merged to the branch mainline in revision 2146.
  • Revision ID: v.ladeuil+lp@free.fr-20061012142932-7221fe16d2b48fa3
Shuffle http related test code. Hopefully it ends up at the right place :)

* bzrlib/tests/HttpServer.py: 
New file. bzrlib.tests.ChrootedTestCase use HttpServer. So the
class can't be defined in bzrlib.tests.HTTPUtils because it
creates a circular dependency (bzrlib.tests.HTTPUtils needs to
import bzrlib.tests).

* bzrlib/transport/http/_urllib.py: 
Transfer test server definition to bzrlib.tests.HttpServer. Clean
up imports.

* bzrlib/transport/http/_pycurl.py: 
Transfer test server definition to bzrlib.tests.HttpServer. Clean
up imports.

* bzrlib/transport/http/__init__.py: 
Transfer all test related code to either bzrlib.tests.HttpServer
and bzrlib.tests.HTTPUtils.
Fix all use of TransportNotPossible and InvalidURL by prefixing it
by 'errors.' (this seems to be the preferred way in the rest of
bzr).
Get rid of unused imports.

* bzrlib/tests/test_transport.py:
(ReadonlyDecoratorTransportTest.test_local_parameters,
FakeNFSDecoratorTests.test_http_parameters): Use HttpServer from
bzrlib.tests.HttpServer instead of bzrlib.transport.http.

* bzrlib/tests/test_sftp_transport.py:
(set_test_transport_to_sftp): Use HttpServer from
bzrlib.tests.HttpServer instead of bzrlib.transport.http.

* bzrlib/tests/test_selftest.py:
(TestTestCaseWithTransport.test_get_readonly_url_http): Use
HttpServer from bzrlib.tests.HttpServer instead of
bzrlib.transport.http.

* bzrlib/tests/test_repository.py: 
Does *not* use HttpServer.

* bzrlib/tests/test_http.py: 
Build on top of bzrlib.tests.HttpServer and bzrlib.tests.HTTPUtils
instead of bzrlib.transport.http.

* bzrlib/tests/test_bzrdir.py:
(ChrootedTests.setUp): Use HttpServer from bzrlib.tests.HttpServer
instead of bzrlib.transport.http.

* bzrlib/tests/branch_implementations/test_http.py:
(HTTPBranchTests.setUp): Use HttpServer from bzrlib.tests.HttpServer
instead of bzrlib.transport.http.

* bzrlib/tests/branch_implementations/test_branch.py:
(ChrootedTests.setUp): Use HttpServer from bzrlib.tests.HttpServer
instead of bzrlib.transport.http.

* bzrlib/tests/__init__.py:
(ChrootedTestCase.setUp): Use HttpServer from
bzrlib.tests.HttpServer instead of bzrlib.transport.http.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006 by Canonical Ltd
 
2
#
 
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.
 
7
#
 
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.
 
12
#
 
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
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
 
17
 
 
18
"""Test "bzr init"""
 
19
 
 
20
import os
 
21
import re
 
22
 
 
23
from bzrlib.bzrdir import BzrDirMetaFormat1
 
24
from bzrlib.tests.blackbox import ExternalBase
 
25
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
 
26
from bzrlib.workingtree import WorkingTree
 
27
 
 
28
 
 
29
class TestInit(ExternalBase):
 
30
 
 
31
    def test_init_with_format(self):
 
32
        # Verify bzr init --format constructs something plausible
 
33
        t = self.get_transport()
 
34
        self.runbzr('init --format default')
 
35
        self.assertIsDirectory('.bzr', t)
 
36
        self.assertIsDirectory('.bzr/checkout', t)
 
37
        self.assertIsDirectory('.bzr/checkout/lock', t)
 
38
 
 
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)
 
44
        self.assertEqual('', err)
 
45
 
 
46
    def test_init_at_repository_root(self):
 
47
        # bzr init at the root of a repository should create a branch
 
48
        # and working tree even when creation of working trees is disabled.
 
49
        t = self.get_transport()
 
50
        t.mkdir('repo')
 
51
        format = BzrDirMetaFormat1()
 
52
        newdir = format.initialize(t.abspath('repo'))
 
53
        repo = newdir.create_repository(shared=True)
 
54
        repo.set_make_working_trees(False)
 
55
        out, err = self.run_bzr('init', 'repo')
 
56
        self.assertEqual('', out)
 
57
        self.assertEqual('', err)
 
58
        newdir.open_branch()
 
59
        newdir.open_workingtree()
 
60
        
 
61
    def test_init_branch(self):
 
62
        out, err = self.run_bzr('init')
 
63
        self.assertEqual('', out)
 
64
        self.assertEqual('', err)
 
65
 
 
66
        # Can it handle subdirectories of branches too ?
 
67
        out, err = self.run_bzr('init', 'subdir1')
 
68
        self.assertEqual('', out)
 
69
        self.assertEqual('', err)
 
70
        WorkingTree.open('subdir1')
 
71
        
 
72
        out, err = self.run_bzr('init', 'subdir2/nothere', retcode=3)
 
73
        self.assertEqual('', out)
 
74
        self.assertContainsRe(err,
 
75
            r'^bzr: ERROR: .*'
 
76
            '\[Errno 2\] No such file or directory')
 
77
        
 
78
        os.mkdir('subdir2')
 
79
        out, err = self.run_bzr('init', 'subdir2')
 
80
        self.assertEqual('', out)
 
81
        self.assertEqual('', err)
 
82
        # 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:'))
 
86
 
 
87
    def test_init_existing_branch(self):
 
88
        self.run_bzr('init')
 
89
        out, err = self.run_bzr('init', retcode=3)
 
90
        self.assertContainsRe(err, 'Already a branch')
 
91
        # don't suggest making a checkout, there's already a working tree
 
92
        self.assertFalse(re.search(r'checkout', err))
 
93
 
 
94
    def test_init_existing_without_workingtree(self):
 
95
        # make a repository
 
96
        self.run_bzr('init-repo', '.')
 
97
        # make a branch; by default without a working tree
 
98
        self.run_bzr('init', 'subdir')
 
99
        # fail
 
100
        out, err = self.run_bzr('init', 'subdir', retcode=3)
 
101
        # suggests using checkout
 
102
        self.assertContainsRe(err, 'ontains a branch.*but no working tree.*checkout')
 
103
 
 
104
    def test_no_defaults(self):
 
105
        """Init creates no default ignore rules."""
 
106
        self.run_bzr('init')
 
107
        self.assertFalse(os.path.exists('.bzrignore'))
 
108
 
 
109
 
 
110
class TestSFTPInit(TestCaseWithSFTPServer):
 
111
 
 
112
    def test_init(self):
 
113
        # init on a remote url should succeed.
 
114
        out, err = self.run_bzr('init', self.get_url())
 
115
        self.assertEqual('', out)
 
116
        self.assertEqual('', err)
 
117
    
 
118
    def test_init_existing_branch(self):
 
119
        # when there is already a branch present, make mention
 
120
        self.make_branch('.')
 
121
 
 
122
        # rely on SFTPServer get_url() pointing at '.'
 
123
        out, err = self.run_bzr_error(['Already a branch'], 'init', self.get_url())
 
124
 
 
125
        # make sure using 'bzr checkout' is not suggested
 
126
        # for remote locations missing a working tree
 
127
        self.assertFalse(re.search(r'checkout', err))
 
128
 
 
129
    def test_init_existing_branch_with_workingtree(self):
 
130
        # don't distinguish between the branch having a working tree or not
 
131
        # when the branch itself is remote.
 
132
        self.make_branch_and_tree('.')
 
133
 
 
134
        # rely on SFTPServer get_url() pointing at '.'
 
135
        self.run_bzr_error(['Already a branch'], 'init', self.get_url())