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