~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

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

(vila) Fix test failures blocking package builds. (Vincent Ladeuil)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2010 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
16
 
 
17
 
 
18
"""Black-box tests for bzr config."""
 
19
 
 
20
from bzrlib import (
 
21
    config,
 
22
    tests,
 
23
    )
 
24
from bzrlib.tests import (
 
25
    script,
 
26
    test_config as _t_config,
 
27
    )
 
28
from bzrlib.tests.matchers import ContainsNoVfsCalls
 
29
 
 
30
 
 
31
class TestWithoutConfig(tests.TestCaseWithTransport):
 
32
 
 
33
    def test_config_all(self):
 
34
        out, err = self.run_bzr(['config'])
 
35
        self.assertEquals('', out)
 
36
        self.assertEquals('', err)
 
37
 
 
38
    def test_remove_unknown_option(self):
 
39
        self.run_bzr_error(['The "file" configuration option does not exist',],
 
40
                           ['config', '--remove', 'file'])
 
41
 
 
42
    def test_all_remove_exclusive(self):
 
43
        self.run_bzr_error(['--all and --remove are mutually exclusive.',],
 
44
                           ['config', '--remove', '--all'])
 
45
 
 
46
    def test_all_set_exclusive(self):
 
47
        self.run_bzr_error(['Only one option can be set.',],
 
48
                           ['config', '--all', 'hello=world'])
 
49
 
 
50
    def test_remove_no_option(self):
 
51
        self.run_bzr_error(['--remove expects an option to remove.',],
 
52
                           ['config', '--remove'])
 
53
 
 
54
    def test_unknown_option(self):
 
55
        self.run_bzr_error(['The "file" configuration option does not exist',],
 
56
                           ['config', 'file'])
 
57
 
 
58
    def test_unexpected_regexp(self):
 
59
        self.run_bzr_error(
 
60
            ['The "\*file" configuration option does not exist',],
 
61
            ['config', '*file'])
 
62
 
 
63
    def test_wrong_regexp(self):
 
64
        self.run_bzr_error(
 
65
            ['Invalid pattern\(s\) found. "\*file" nothing to repeat',],
 
66
            ['config', '--all', '*file'])
 
67
 
 
68
 
 
69
 
 
70
class TestConfigDisplay(tests.TestCaseWithTransport):
 
71
 
 
72
    def setUp(self):
 
73
        super(TestConfigDisplay, self).setUp()
 
74
        _t_config.create_configs(self)
 
75
 
 
76
    def test_multiline_all_values(self):
 
77
        self.bazaar_config.set_user_option('multiline', '1\n2\n')
 
78
        # Fallout from bug 710410, the triple quotes have been toggled
 
79
        script.run_script(self, '''\
 
80
            $ bzr config -d tree
 
81
            bazaar:
 
82
              [DEFAULT]
 
83
              multiline = """1
 
84
            2
 
85
            """
 
86
            ''')
 
87
 
 
88
    def test_multiline_value_only(self):
 
89
        self.bazaar_config.set_user_option('multiline', '1\n2\n')
 
90
        # Fallout from bug 710410, the triple quotes have been toggled
 
91
        script.run_script(self, '''\
 
92
            $ bzr config -d tree multiline
 
93
            """1
 
94
            2
 
95
            """
 
96
            ''')
 
97
 
 
98
    def test_list_value_all(self):
 
99
        config.option_registry.register(config.ListOption('list'))
 
100
        self.addCleanup(config.option_registry.remove, 'list')
 
101
        self.bazaar_config.set_user_option('list', [1, 'a', 'with, a comma'])
 
102
        script.run_script(self, '''\
 
103
            $ bzr config -d tree
 
104
            bazaar:
 
105
              [DEFAULT]
 
106
              list = 1, a, "with, a comma"
 
107
            ''')
 
108
 
 
109
    def test_list_value_one(self):
 
110
        config.option_registry.register(config.ListOption('list'))
 
111
        self.addCleanup(config.option_registry.remove, 'list')
 
112
        self.bazaar_config.set_user_option('list', [1, 'a', 'with, a comma'])
 
113
        script.run_script(self, '''\
 
114
            $ bzr config -d tree list
 
115
            1, a, "with, a comma"
 
116
            ''')
 
117
 
 
118
    def test_registry_value_all(self):
 
119
        self.bazaar_config.set_user_option('bzr.transform.orphan_policy',
 
120
                                           u'move')
 
121
        script.run_script(self, '''\
 
122
            $ bzr config -d tree
 
123
            bazaar:
 
124
              [DEFAULT]
 
125
              bzr.transform.orphan_policy = move
 
126
            ''')
 
127
 
 
128
    def test_registry_value_one(self):
 
129
        self.bazaar_config.set_user_option('bzr.transform.orphan_policy',
 
130
                                           u'move')
 
131
        script.run_script(self, '''\
 
132
            $ bzr config -d tree bzr.transform.orphan_policy
 
133
            move
 
134
            ''')
 
135
 
 
136
    def test_bazaar_config(self):
 
137
        self.bazaar_config.set_user_option('hello', 'world')
 
138
        script.run_script(self, '''\
 
139
            $ bzr config -d tree
 
140
            bazaar:
 
141
              [DEFAULT]
 
142
              hello = world
 
143
            ''')
 
144
 
 
145
    def test_locations_config_for_branch(self):
 
146
        self.locations_config.set_user_option('hello', 'world')
 
147
        self.branch_config.set_user_option('hello', 'you')
 
148
        script.run_script(self, '''\
 
149
            $ bzr config -d tree
 
150
            locations:
 
151
              [.../tree]
 
152
              hello = world
 
153
            branch:
 
154
              hello = you
 
155
            ''')
 
156
 
 
157
    def test_locations_config_outside_branch(self):
 
158
        self.bazaar_config.set_user_option('hello', 'world')
 
159
        self.locations_config.set_user_option('hello', 'world')
 
160
        script.run_script(self, '''\
 
161
            $ bzr config
 
162
            bazaar:
 
163
              [DEFAULT]
 
164
              hello = world
 
165
            ''')
 
166
 
 
167
    def test_cmd_line(self):
 
168
        self.bazaar_config.set_user_option('hello', 'world')
 
169
        script.run_script(self, '''\
 
170
            $ bzr config -Ohello=bzr
 
171
            cmdline:
 
172
              hello = bzr
 
173
            bazaar:
 
174
              [DEFAULT]
 
175
              hello = world
 
176
            ''')
 
177
 
 
178
 
 
179
class TestConfigDisplayWithPolicy(tests.TestCaseWithTransport):
 
180
 
 
181
    def test_location_with_policy(self):
 
182
        # LocationConfig is the only one dealing with policies so far.
 
183
        self.make_branch_and_tree('tree')
 
184
        config_text = """\
 
185
[%(dir)s]
 
186
url = dir
 
187
url:policy = appendpath
 
188
[%(dir)s/tree]
 
189
url = tree
 
190
""" % {'dir': self.test_dir}
 
191
        # We don't use the config directly so we save it to disk
 
192
        config.LocationConfig.from_string(config_text, 'tree', save=True)
 
193
        # policies are displayed with their options since they are part of
 
194
        # their definition, likewise the path is not appended, we are just
 
195
        # presenting the relevant portions of the config files
 
196
        script.run_script(self, '''\
 
197
            $ bzr config -d tree --all url
 
198
            locations:
 
199
              [.../work/tree]
 
200
              url = tree
 
201
              [.../work]
 
202
              url = dir
 
203
              url:policy = appendpath
 
204
            ''')
 
205
 
 
206
 
 
207
class TestConfigActive(tests.TestCaseWithTransport):
 
208
 
 
209
    def setUp(self):
 
210
        super(TestConfigActive, self).setUp()
 
211
        _t_config.create_configs_with_file_option(self)
 
212
 
 
213
    def test_active_in_locations(self):
 
214
        script.run_script(self, '''\
 
215
            $ bzr config -d tree file
 
216
            locations
 
217
            ''')
 
218
 
 
219
    def test_active_in_bazaar(self):
 
220
        script.run_script(self, '''\
 
221
            $ bzr config -d tree --scope bazaar file
 
222
            bazaar
 
223
            ''')
 
224
 
 
225
    def test_active_in_branch(self):
 
226
        # We need to delete the locations definition that overrides the branch
 
227
        # one
 
228
        script.run_script(self, '''\
 
229
            $ bzr config -d tree --scope locations --remove file
 
230
            $ bzr config -d tree file
 
231
            branch
 
232
            ''')
 
233
 
 
234
 
 
235
class TestConfigSetOption(tests.TestCaseWithTransport):
 
236
 
 
237
    def setUp(self):
 
238
        super(TestConfigSetOption, self).setUp()
 
239
        _t_config.create_configs(self)
 
240
 
 
241
    def test_unknown_config(self):
 
242
        self.run_bzr_error(['The "moon" configuration does not exist'],
 
243
                           ['config', '--scope', 'moon', 'hello=world'])
 
244
 
 
245
    def test_bazaar_config_outside_branch(self):
 
246
        script.run_script(self, '''\
 
247
            $ bzr config --scope bazaar hello=world
 
248
            $ bzr config -d tree --all hello
 
249
            bazaar:
 
250
              [DEFAULT]
 
251
              hello = world
 
252
            ''')
 
253
 
 
254
    def test_bazaar_config_inside_branch(self):
 
255
        script.run_script(self, '''\
 
256
            $ bzr config -d tree --scope bazaar hello=world
 
257
            $ bzr config -d tree --all hello
 
258
            bazaar:
 
259
              [DEFAULT]
 
260
              hello = world
 
261
            ''')
 
262
 
 
263
    def test_locations_config_inside_branch(self):
 
264
        script.run_script(self, '''\
 
265
            $ bzr config -d tree --scope locations hello=world
 
266
            $ bzr config -d tree --all hello
 
267
            locations:
 
268
              [.../work/tree]
 
269
              hello = world
 
270
            ''')
 
271
 
 
272
    def test_branch_config_default(self):
 
273
        script.run_script(self, '''\
 
274
            $ bzr config -d tree hello=world
 
275
            $ bzr config -d tree --all hello
 
276
            branch:
 
277
              hello = world
 
278
            ''')
 
279
 
 
280
    def test_branch_config_forcing_branch(self):
 
281
        script.run_script(self, '''\
 
282
            $ bzr config -d tree --scope branch hello=world
 
283
            $ bzr config -d tree --all hello
 
284
            branch:
 
285
              hello = world
 
286
            ''')
 
287
 
 
288
 
 
289
class TestConfigRemoveOption(tests.TestCaseWithTransport):
 
290
 
 
291
    def setUp(self):
 
292
        super(TestConfigRemoveOption, self).setUp()
 
293
        _t_config.create_configs_with_file_option(self)
 
294
 
 
295
    def test_unknown_config(self):
 
296
        self.run_bzr_error(['The "moon" configuration does not exist'],
 
297
                           ['config', '--scope', 'moon', '--remove', 'file'])
 
298
 
 
299
    def test_bazaar_config_outside_branch(self):
 
300
        script.run_script(self, '''\
 
301
            $ bzr config --scope bazaar --remove file
 
302
            $ bzr config -d tree --all file
 
303
            locations:
 
304
              [.../work/tree]
 
305
              file = locations
 
306
            branch:
 
307
              file = branch
 
308
            ''')
 
309
 
 
310
    def test_bazaar_config_inside_branch(self):
 
311
        script.run_script(self, '''\
 
312
            $ bzr config -d tree --scope bazaar --remove file
 
313
            $ bzr config -d tree --all file
 
314
            locations:
 
315
              [.../work/tree]
 
316
              file = locations
 
317
            branch:
 
318
              file = branch
 
319
            ''')
 
320
 
 
321
    def test_locations_config_inside_branch(self):
 
322
        script.run_script(self, '''\
 
323
            $ bzr config -d tree --scope locations --remove file
 
324
            $ bzr config -d tree --all file
 
325
            branch:
 
326
              file = branch
 
327
            bazaar:
 
328
              [DEFAULT]
 
329
              file = bazaar
 
330
            ''')
 
331
 
 
332
    def test_branch_config_default(self):
 
333
        script.run_script(self, '''\
 
334
            $ bzr config -d tree --scope locations --remove file
 
335
            $ bzr config -d tree --all file
 
336
            branch:
 
337
              file = branch
 
338
            bazaar:
 
339
              [DEFAULT]
 
340
              file = bazaar
 
341
            ''')
 
342
        script.run_script(self, '''\
 
343
            $ bzr config -d tree --remove file
 
344
            $ bzr config -d tree --all file
 
345
            bazaar:
 
346
              [DEFAULT]
 
347
              file = bazaar
 
348
            ''')
 
349
 
 
350
    def test_branch_config_forcing_branch(self):
 
351
        script.run_script(self, '''\
 
352
            $ bzr config -d tree --scope branch --remove file
 
353
            $ bzr config -d tree --all file
 
354
            locations:
 
355
              [.../work/tree]
 
356
              file = locations
 
357
            bazaar:
 
358
              [DEFAULT]
 
359
              file = bazaar
 
360
            ''')
 
361
        script.run_script(self, '''\
 
362
            $ bzr config -d tree --scope locations --remove file
 
363
            $ bzr config -d tree --all file
 
364
            bazaar:
 
365
              [DEFAULT]
 
366
              file = bazaar
 
367
            ''')
 
368
 
 
369
 
 
370
class TestSmartServerConfig(tests.TestCaseWithTransport):
 
371
 
 
372
    def test_simple_branch_config(self):
 
373
        self.setup_smart_server_with_call_log()
 
374
        t = self.make_branch_and_tree('branch')
 
375
        self.reset_smart_call_log()
 
376
        out, err = self.run_bzr(['config', '-d', self.get_url('branch')])
 
377
        # This figure represent the amount of work to perform this use case. It
 
378
        # is entirely ok to reduce this number if a test fails due to rpc_count
 
379
        # being too low. If rpc_count increases, more network roundtrips have
 
380
        # become necessary for this use case. Please do not adjust this number
 
381
        # upwards without agreement from bzr's network support maintainers.
 
382
        self.assertLength(5, self.hpss_calls)
 
383
        self.assertLength(1, self.hpss_connections)
 
384
        self.assertThat(self.hpss_calls, ContainsNoVfsCalls)
 
385
 
 
386
 
 
387
class TestConfigDirectory(tests.TestCaseWithTransport):
 
388
 
 
389
    def test_parent_alias(self):
 
390
        t = self.make_branch_and_tree('base')
 
391
        t.branch.get_config_stack().set('test', 'base')
 
392
        clone = t.branch.bzrdir.sprout('clone').open_branch()
 
393
        clone.get_config_stack().set('test', 'clone')
 
394
        out, err = self.run_bzr(['config', '-d', ':parent', 'test'],
 
395
                                working_dir='clone')
 
396
        self.assertEquals('base\n', out)