1
# Copyright (C) 2005, 2006, 2007 Canonical Ltd
1
# Copyright (C) 2005-2010 Canonical Ltd
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
13
13
# You should have received a copy of the GNU General Public License
14
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
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
19
from bzrlib import (
28
from bzrlib.builtins import cmd_commit, cmd_log, cmd_status
26
from bzrlib.builtins import cmd_commit
29
27
from bzrlib.commands import Command, parse_args
30
28
from bzrlib.tests import TestCase
31
29
from bzrlib.repofmt import knitrepo
42
40
def test_parse_args(self):
43
41
"""Option parser"""
44
eq = self.assertEquals
45
eq(parse_args(cmd_commit(), ['--help']),
46
([], {'fixes': [], 'help': True}))
47
eq(parse_args(cmd_commit(), ['--message=biter']),
48
([], {'fixes': [], 'message': 'biter'}))
42
# XXX: Using cmd_commit makes these tests overly sensitive to changes
43
# to cmd_commit, when they are meant to be about option parsing in
45
self.assertEqual(parse_args(cmd_commit(), ['--help']),
46
([], {'author': [], 'exclude': [], 'fixes': [], 'help': True}))
47
self.assertEqual(parse_args(cmd_commit(), ['--message=biter']),
48
([], {'author': [], 'exclude': [], 'fixes': [], 'message': 'biter'}))
50
50
def test_no_more_opts(self):
51
51
"""Terminated options"""
52
self.assertEquals(parse_args(cmd_commit(), ['--', '-file-with-dashes']),
53
(['-file-with-dashes'], {'fixes': []}))
52
self.assertEqual(parse_args(cmd_commit(), ['--', '-file-with-dashes']),
53
(['-file-with-dashes'], {'author': [], 'exclude': [], 'fixes': []}))
55
55
def test_option_help(self):
56
56
"""Options have help strings."""
67
67
def test_option_arg_help(self):
68
68
"""Help message shows option arguments."""
69
69
out, err = self.run_bzr('help commit')
70
self.assertEquals(err, '')
70
self.assertEqual(err, '')
71
71
self.assertContainsRe(out, r'--file[ =]MSGFILE')
73
73
def test_unknown_short_opt(self):
82
82
def test_allow_dash(self):
83
83
"""Test that we can pass a plain '-' as an argument."""
85
(['-'], {'fixes': []}), parse_args(cmd_commit(), ['-']))
84
self.assertEqual((['-']), parse_args(cmd_commit(), ['-'])[0])
87
86
def parse(self, options, args):
88
87
parser = option.get_optparser(dict((o.name, o) for o in options))
104
103
self.assertRaises(errors.BzrCommandError, self.parse, options,
106
def test_is_hidden(self):
107
self.assertTrue(option.Option('foo', hidden=True).is_hidden('foo'))
108
self.assertFalse(option.Option('foo', hidden=False).is_hidden('foo'))
107
110
def test_registry_conversion(self):
108
registry = bzrdir.BzrDirFormatRegistry()
109
registry.register_metadir('one', 'RepositoryFormat7', 'one help')
110
registry.register_metadir('two', 'RepositoryFormatKnit1', 'two help')
111
registry.register_metadir('hidden', 'RepositoryFormatKnit1',
111
registry = controldir.ControlDirFormatRegistry()
112
bzrdir.register_metadir(registry, 'one', 'RepositoryFormat7', 'one help')
113
bzrdir.register_metadir(registry, 'two', 'RepositoryFormatKnit1', 'two help')
114
bzrdir.register_metadir(registry, 'hidden', 'RepositoryFormatKnit1',
112
115
'two help', hidden=True)
113
116
registry.set_default('one')
114
117
options = [option.RegistryOption('format', '', registry, str)]
153
156
self.assertIsInstance(opts.format.repository_format,
154
157
knitrepo.RepositoryFormatKnit1)
159
def test_lazy_registry(self):
160
options = [option.RegistryOption('format', '',
161
lazy_registry=('bzrlib.bzrdir','format_registry'),
163
opts, args = self.parse(options, ['--format', 'knit'])
164
self.assertEqual({'format': 'knit'}, opts)
166
errors.BadOptionValue, self.parse, options, ['--format', 'BAD'])
156
168
def test_from_kwargs(self):
157
169
my_option = option.RegistryOption.from_kwargs('my-option',
158
170
help='test option', short='be short', be_long='go long')
166
178
self.assertEqual('test option', my_option.help)
168
180
def test_help(self):
169
registry = bzrdir.BzrDirFormatRegistry()
170
registry.register_metadir('one', 'RepositoryFormat7', 'one help')
171
registry.register_metadir('two',
181
registry = controldir.ControlDirFormatRegistry()
182
bzrdir.register_metadir(registry, 'one', 'RepositoryFormat7', 'one help')
183
bzrdir.register_metadir(registry, 'two',
172
184
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
175
registry.register_metadir('hidden', 'RepositoryFormat7', 'hidden help',
187
bzrdir.register_metadir(registry, 'hidden', 'RepositoryFormat7', 'hidden help',
177
189
registry.set_default('one')
178
190
options = [option.RegistryOption('format', 'format help', registry,
194
206
opt = option.Option('hello', help='fg', type=int, argname='gar')
195
207
self.assertEqual(list(opt.iter_switches()),
196
208
[('hello', None, 'GAR', 'fg')])
197
registry = bzrdir.BzrDirFormatRegistry()
198
registry.register_metadir('one', 'RepositoryFormat7', 'one help')
199
registry.register_metadir('two',
209
registry = controldir.ControlDirFormatRegistry()
210
bzrdir.register_metadir(registry, 'one', 'RepositoryFormat7', 'one help')
211
bzrdir.register_metadir(registry, 'two',
200
212
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
258
270
opts, args = self.parse(options, ['--hello=world', '--hello=sailor'])
259
271
self.assertEqual(['world', 'sailor'], opts.hello)
273
def test_list_option_with_dash(self):
274
options = [option.ListOption('with-dash', type=str)]
275
opts, args = self.parse(options, ['--with-dash=world',
276
'--with-dash=sailor'])
277
self.assertEqual(['world', 'sailor'], opts.with_dash)
261
279
def test_list_option_no_arguments(self):
262
280
options = [option.ListOption('hello', type=str)]
263
281
opts, args = self.parse(options, [])
301
319
self.assertEqual('hello', name)
302
320
self.assertEqual([], value)
322
def test_list_option_param_name(self):
323
"""Test list options can have their param_name set."""
324
options = [option.ListOption('hello', type=str, param_name='greeting')]
325
opts, args = self.parse(
326
options, ['--hello=world', '--hello=sailor'])
327
self.assertEqual(['world', 'sailor'], opts.greeting)
305
330
class TestOptionDefinitions(TestCase):
306
331
"""Tests for options in the Bazaar codebase."""
308
333
def get_builtin_command_options(self):
310
for cmd_name, cmd_class in sorted(commands.get_all_cmds()):
335
for cmd_name in sorted(commands.all_command_names()):
336
cmd = commands.get_cmd_object(cmd_name)
312
337
for opt_name, opt in sorted(cmd.options().items()):
313
338
g.append((cmd_name, opt))
321
346
g = dict(option.Option.OPTIONS.items())
322
347
used_globals = {}
324
for cmd_name, cmd_class in sorted(commands.get_all_cmds()):
325
for option_or_name in sorted(cmd_class.takes_options):
349
for cmd_name in sorted(commands.all_command_names()):
350
cmd = commands.get_cmd_object(cmd_name)
351
for option_or_name in sorted(cmd.takes_options):
326
352
if not isinstance(option_or_name, basestring):
327
353
self.assertIsInstance(option_or_name, option.Option)
328
354
elif not option_or_name in g:
329
355
msgs.append("apparent reference to undefined "
330
356
"global option %r from %r"
331
% (option_or_name, cmd_class))
357
% (option_or_name, cmd))
333
359
used_globals.setdefault(option_or_name, []).append(cmd_name)
334
360
unused_globals = set(g.keys()) - set(used_globals.keys())
349
375
# period and be all on a single line, because the display code will
351
377
option_re = re.compile(r'^[A-Z][^\n]+\.$')
352
for scope, option in self.get_builtin_command_options():
354
msgs.append('%-16s %-16s %s' %
355
((scope or 'GLOBAL'), option.name, 'NO HELP'))
356
elif not option_re.match(option.help):
357
msgs.append('%-16s %-16s %s' %
358
((scope or 'GLOBAL'), option.name, option.help))
378
for scope, opt in self.get_builtin_command_options():
380
msgs.append('%-16s %-16s %s' %
381
((scope or 'GLOBAL'), opt.name, 'NO HELP'))
382
elif not option_re.match(opt.help):
383
msgs.append('%-16s %-16s %s' %
384
((scope or 'GLOBAL'), opt.name, opt.help))
360
386
self.fail("The following options don't match the style guide:\n"
361
387
+ '\n'.join(msgs))
363
389
def test_is_hidden(self):
364
registry = bzrdir.BzrDirFormatRegistry()
365
registry.register_metadir('hidden', 'HiddenFormat',
390
registry = controldir.ControlDirFormatRegistry()
391
bzrdir.register_metadir(registry, 'hidden', 'HiddenFormat',
366
392
'hidden help text', hidden=True)
367
registry.register_metadir('visible', 'VisibleFormat',
393
bzrdir.register_metadir(registry, 'visible', 'VisibleFormat',
368
394
'visible help text', hidden=False)
369
395
format = option.RegistryOption('format', '', registry, str)
370
396
self.assertTrue(format.is_hidden('hidden'))