/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
5557.1.7 by John Arbash Meinel
Merge in the bzr.dev 5582
1
# Copyright (C) 2006-2011 Canonical Ltd
1558.5.1 by Aaron Bentley
Added make-repository command
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
4183.7.1 by Sabin Iacob
update FSF mailing address
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
1558.5.1 by Aaron Bentley
Added make-repository command
16
17
"""Black-box tests for repositories with shared branches"""
18
19
import os
20
4734.4.9 by Andrew Bennetts
More tests and comments.
21
from bzrlib.bzrdir import BzrDir, BzrDirMetaFormat1
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
22
import bzrlib.errors as errors
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
23
from bzrlib.tests import TestCaseInTempDir
6366.1.4 by Jelmer Vernooij
Test connection count calls for most blackbox commands.
24
from bzrlib.tests.matchers import ContainsNoVfsCalls
25
1558.5.1 by Aaron Bentley
Added make-repository command
26
27
class TestSharedRepo(TestCaseInTempDir):
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
28
1558.5.4 by Aaron Bentley
Added bzr init test
29
    def test_make_repository(self):
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
30
        out, err = self.run_bzr("init-repository a")
3535.9.5 by Marius Kruger
remove a trailing space I added
31
        self.assertEqual(out,
4599.4.8 by Robert Collins
Update blackbox.test_shared_repository for 2a as default.
32
"""Shared repository with trees (format: 2a)
3535.9.2 by Marius Kruger
make init and init-repo tests pass again
33
Location:
34
  shared repository: a
35
""")
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
36
        self.assertEqual(err, "")
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
37
        dir = BzrDir.open('a')
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
38
        self.assertIs(dir.open_repository().is_shared(), True)
39
        self.assertRaises(errors.NotBranchError, dir.open_branch)
3535.9.6 by Marius Kruger
add explicit blackbox tests for 'init -q' and 'init-repo -q'
40
        self.assertRaises(errors.NoWorkingTree, dir.open_workingtree)
41
42
    def test_make_repository_quiet(self):
43
        out, err = self.run_bzr("init-repository a -q")
44
        self.assertEqual(out, "")
45
        self.assertEqual(err, "")
46
        dir = BzrDir.open('a')
47
        self.assertIs(dir.open_repository().is_shared(), True)
48
        self.assertRaises(errors.NotBranchError, dir.open_branch)
49
        self.assertRaises(errors.NoWorkingTree, dir.open_workingtree)
1558.5.4 by Aaron Bentley
Added bzr init test
50
1658.1.6 by Martin Pool
init-repo shouldn't insist on creating a new directory (Malone #38331)
51
    def test_init_repo_existing_dir(self):
52
        """Make repo in existing directory.
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
53
1658.1.6 by Martin Pool
init-repo shouldn't insist on creating a new directory (Malone #38331)
54
        (Malone #38331)
55
        """
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
56
        out, err = self.run_bzr("init-repository .")
1658.1.6 by Martin Pool
init-repo shouldn't insist on creating a new directory (Malone #38331)
57
        dir = BzrDir.open('.')
58
        self.assertTrue(dir.open_repository())
59
1558.5.4 by Aaron Bentley
Added bzr init test
60
    def test_init(self):
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
61
        self.run_bzr("init-repo a")
62
        self.run_bzr("init --format=default a/b")
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
63
        dir = BzrDir.open('a')
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
64
        self.assertIs(dir.open_repository().is_shared(), True)
65
        self.assertRaises(errors.NotBranchError, dir.open_branch)
66
        self.assertRaises(errors.NoWorkingTree, dir.open_workingtree)
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
67
        bdir = BzrDir.open('a/b')
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
68
        bdir.open_branch()
69
        self.assertRaises(errors.NoRepositoryPresent, bdir.open_repository)
2257.2.1 by Wouter van Heyst
Change the ui level default for init-repo to --trees.
70
        wt = bdir.open_workingtree()
1558.5.5 by Aaron Bentley
Added tests for branch
71
72
    def test_branch(self):
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
73
        self.run_bzr("init-repo a")
74
        self.run_bzr("init --format=default a/b")
75
        self.run_bzr('branch a/b a/c')
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
76
        cdir = BzrDir.open('a/c')
1558.5.9 by Aaron Bentley
Updated tests per Robert Collins' suggestions
77
        cdir.open_branch()
78
        self.assertRaises(errors.NoRepositoryPresent, cdir.open_repository)
2257.2.1 by Wouter van Heyst
Change the ui level default for init-repo to --trees.
79
        cdir.open_workingtree()
1624.2.2 by Erik Bågfors
tests for --tree
80
81
    def test_branch_tree(self):
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
82
        self.run_bzr("init-repo --trees a")
83
        self.run_bzr("init --format=default b")
1624.2.2 by Erik Bågfors
tests for --tree
84
        file('b/hello', 'wt').write('bar')
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
85
        self.run_bzr("add b/hello")
86
        self.run_bzr("commit -m bar b/hello")
1624.2.2 by Erik Bågfors
tests for --tree
87
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
88
        self.run_bzr('branch b a/c')
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
89
        cdir = BzrDir.open('a/c')
1624.2.2 by Erik Bågfors
tests for --tree
90
        cdir.open_branch()
91
        self.assertRaises(errors.NoRepositoryPresent, cdir.open_repository)
5784.1.3 by Martin Pool
Switch away from using failUnlessExists and failIfExists
92
        self.assertPathExists('a/c/hello')
1624.2.3 by Erik Bågfors
better test for --tree option
93
        cdir.open_workingtree()
1624.2.2 by Erik Bågfors
tests for --tree
94
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
95
    def test_trees_default(self):
96
        # 0.15 switched to trees by default
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
97
        self.run_bzr("init-repo repo")
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
98
        repo = BzrDir.open("repo").open_repository()
99
        self.assertEqual(True, repo.make_working_trees())
100
101
    def test_trees_argument(self):
102
        # Supplying the --trees argument should be harmless,
103
        # as it was previously non-default we need to get it right.
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
104
        self.run_bzr("init-repo --trees trees")
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
105
        repo = BzrDir.open("trees").open_repository()
106
        self.assertEqual(True, repo.make_working_trees())
107
108
    def test_no_trees_argument(self):
109
        # --no-trees should make it so that there is no working tree
2552.2.3 by Vincent Ladeuil
Deprecate the varargs syntax and fix the tests.
110
        self.run_bzr("init-repo --no-trees notrees")
2257.2.2 by Wouter van Heyst
Actually test that `bzr init-repo --{no,}-trees` still works
111
        repo = BzrDir.open("notrees").open_repository()
112
        self.assertEqual(False, repo.make_working_trees())
4017.3.1 by Robert Collins
Add effort test for init-repo on smart server urls.
113
114
    def test_init_repo_smart_acceptance(self):
115
        # The amount of hpss calls made on init-repo to a smart server should
116
        # be fixed.
117
        self.setup_smart_server_with_call_log()
118
        self.run_bzr(['init-repo', self.get_url('repo')])
119
        # This figure represent the amount of work to perform this use case. It
120
        # is entirely ok to reduce this number if a test fails due to rpc_count
121
        # being too low. If rpc_count increases, more network roundtrips have
122
        # become necessary for this use case. Please do not adjust this number
123
        # upwards without agreement from bzr's network support maintainers.
6366.1.11 by Jelmer Vernooij
Fix tests.
124
        self.assertLength(10, self.hpss_calls)
6366.1.4 by Jelmer Vernooij
Test connection count calls for most blackbox commands.
125
        self.assertLength(1, self.hpss_connections)
126
        self.assertThat(self.hpss_calls, ContainsNoVfsCalls)
4734.4.4 by Brian de Alwis
Added tests to ensure branching-from-repository error returns detail
127
128
    def test_notification_on_branch_from_repository(self):
129
        out, err = self.run_bzr("init-repository -q a")
130
        self.assertEqual(out, "")
131
        self.assertEqual(err, "")
132
        dir = BzrDir.open('a')
4734.4.7 by Andrew Bennetts
Defer checking for a repository in NotBranchError case until we format the error as a string. (test_smart currently fails)
133
        dir.open_repository() # there is a repository there
4734.4.4 by Brian de Alwis
Added tests to ensure branching-from-repository error returns detail
134
        e = self.assertRaises(errors.NotBranchError, dir.open_branch)
4734.4.7 by Andrew Bennetts
Defer checking for a repository in NotBranchError case until we format the error as a string. (test_smart currently fails)
135
        self.assertContainsRe(str(e), "location is a repository")
4734.4.9 by Andrew Bennetts
More tests and comments.
136
137
    def test_notification_on_branch_from_nonrepository(self):
138
        fmt = BzrDirMetaFormat1()
139
        t = self.get_transport()
140
        t.mkdir('a')
141
        dir = fmt.initialize_on_transport(t.clone('a'))
142
        self.assertRaises(errors.NoRepositoryPresent, dir.open_repository)
143
        e = self.assertRaises(errors.NotBranchError, dir.open_branch)
144
        self.assertNotContainsRe(str(e), "location is a repository")
5107.3.6 by Marco Pantaleoni
Documented behaviour of 'post_branch_init' for lightweight checkouts.
145
146
    def test_init_repo_with_post_repo_init_hook(self):
147
        calls = []
148
        BzrDir.hooks.install_named_hook('post_repo_init', calls.append, None)
149
        self.assertLength(0, calls)
150
        self.run_bzr("init-repository a")
151
        self.assertLength(1, calls)
5187.2.4 by Parth Malwankar
added tests.
152
5187.2.6 by Parth Malwankar
lockdir no long mandates whoami but uses unicode version of getuser
153
    def test_init_repo_without_username(self):
154
        """Ensure init-repo works if username is not set.
5187.2.4 by Parth Malwankar
added tests.
155
        """
5187.2.9 by Parth Malwankar
added comment to init/init-repo pass tests for lacking whoami.
156
        # bzr makes user specified whoami mandatory for operations
157
        # like commit as whoami is recorded. init-repo however is not so final
158
        # and uses whoami only in a lock file. Without whoami the login name
159
        # is used. This test is to ensure that init-repo passes even when whoami
160
        # is not available.
5570.3.12 by Vincent Ladeuil
Replace osutils.set_or_unset_env calls with self.overrideEnv.
161
        self.overrideEnv('EMAIL', None)
162
        self.overrideEnv('BZR_EMAIL', None)
5187.2.6 by Parth Malwankar
lockdir no long mandates whoami but uses unicode version of getuser
163
        out, err = self.run_bzr(['init-repo', 'foo'])
164
        self.assertEqual(err, '')
165
        self.assertTrue(os.path.exists('foo'))