74
60
self.assertRaises(errors.BzrCommandError,
75
61
commands.run_bzr, ['log', u'--option\xb5'])
78
def get_command(options):
79
class cmd_foo(commands.Command):
82
takes_options = options
86
def test_help_hidden(self):
87
c = self.get_command([option.Option('foo', hidden=True)])
88
self.assertNotContainsRe(c.get_help_text(), '--foo')
90
def test_help_not_hidden(self):
91
c = self.get_command([option.Option('foo', hidden=False)])
92
self.assertContainsRe(c.get_help_text(), '--foo')
95
64
class TestGetAlias(tests.TestCase):
97
66
def _get_config(self, config_text):
98
my_config = config.GlobalConfig.from_string(config_text)
67
my_config = config.GlobalConfig()
68
config_file = StringIO(config_text.encode('utf-8'))
69
my_config._parser = my_config._get_parser(file=config_file)
101
72
def test_simple(self):
130
101
class TestSeeAlso(tests.TestCase):
131
102
"""Tests for the see also functional of Command."""
134
def _get_command_with_see_also(see_also):
135
class ACommand(commands.Command):
136
__doc__ = """A sample command."""
140
104
def test_default_subclass_no_see_also(self):
141
command = self._get_command_with_see_also([])
105
class ACommand(commands.Command):
106
"""A sample command."""
142
108
self.assertEqual([], command.get_see_also())
144
110
def test__see_also(self):
145
111
"""When _see_also is defined, it sets the result of get_see_also()."""
146
command = self._get_command_with_see_also(['bar', 'foo'])
112
class ACommand(commands.Command):
113
_see_also = ['bar', 'foo']
147
115
self.assertEqual(['bar', 'foo'], command.get_see_also())
149
117
def test_deduplication(self):
150
118
"""Duplicates in _see_also are stripped out."""
151
command = self._get_command_with_see_also(['foo', 'foo'])
119
class ACommand(commands.Command):
120
_see_also = ['foo', 'foo']
152
122
self.assertEqual(['foo'], command.get_see_also())
154
124
def test_sorted(self):
155
125
"""_see_also is sorted by get_see_also."""
156
command = self._get_command_with_see_also(['foo', 'bar'])
126
class ACommand(commands.Command):
127
_see_also = ['foo', 'bar']
157
129
self.assertEqual(['bar', 'foo'], command.get_see_also())
159
131
def test_additional_terms(self):
160
132
"""Additional terms can be supplied and are deduped and sorted."""
161
command = self._get_command_with_see_also(['foo', 'bar'])
133
class ACommand(commands.Command):
134
_see_also = ['foo', 'bar']
162
136
self.assertEqual(['bar', 'foo', 'gam'],
163
137
command.get_see_also(['gam', 'bar', 'gam']))
214
187
# commands are registered).
215
188
# when they are simply created.
217
commands.install_bzr_command_hooks()
218
190
commands.Command.hooks.install_named_hook(
219
191
"extend_command", hook_calls.append, None)
220
192
# create a command, should not fire
221
class cmd_test_extend_command_hook(commands.Command):
222
__doc__ = """A sample command."""
193
class ACommand(commands.Command):
194
"""A sample command."""
223
196
self.assertEqual([], hook_calls)
224
197
# -- as a builtin
225
198
# register the command class, should not fire
227
commands.builtin_command_registry.register(cmd_test_extend_command_hook)
200
builtins.cmd_test_extend_command_hook = ACommand
228
201
self.assertEqual([], hook_calls)
229
202
# and ask for the object, should fire
230
203
cmd = commands.get_cmd_object('test-extend-command-hook')
246
219
self.assertEqual([cmd], hook_calls)
248
221
commands.plugin_cmds.remove('fake')
251
class TestGetCommandHook(tests.TestCase):
253
def test_fires_on_get_cmd_object(self):
254
# The get_command(cmd) hook fires when commands are delivered to the
256
commands.install_bzr_command_hooks()
258
class ACommand(commands.Command):
259
__doc__ = """A sample command."""
260
def get_cmd(cmd_or_None, cmd_name):
261
hook_calls.append(('called', cmd_or_None, cmd_name))
262
if cmd_name in ('foo', 'info'):
264
commands.Command.hooks.install_named_hook(
265
"get_command", get_cmd, None)
266
# create a command directly, should not fire
268
self.assertEqual([], hook_calls)
269
# ask by name, should fire and give us our command
270
cmd = commands.get_cmd_object('foo')
271
self.assertEqual([('called', None, 'foo')], hook_calls)
272
self.assertIsInstance(cmd, ACommand)
274
# ask by a name that is supplied by a builtin - the hook should still
275
# fire and we still get our object, but we should see the builtin
276
# passed to the hook.
277
cmd = commands.get_cmd_object('info')
278
self.assertIsInstance(cmd, ACommand)
279
self.assertEqual(1, len(hook_calls))
280
self.assertEqual('info', hook_calls[0][2])
281
self.assertIsInstance(hook_calls[0][1], builtins.cmd_info)
284
class TestGetMissingCommandHook(tests.TestCase):
286
def hook_missing(self):
287
"""Hook get_missing_command for testing."""
289
class ACommand(commands.Command):
290
__doc__ = """A sample command."""
291
def get_missing_cmd(cmd_name):
292
self.hook_calls.append(('called', cmd_name))
293
if cmd_name in ('foo', 'info'):
295
commands.Command.hooks.install_named_hook(
296
"get_missing_command", get_missing_cmd, None)
297
self.ACommand = ACommand
299
def test_fires_on_get_cmd_object(self):
300
# The get_missing_command(cmd) hook fires when commands are delivered to the
303
# create a command directly, should not fire
304
self.cmd = self.ACommand()
305
self.assertEqual([], self.hook_calls)
306
# ask by name, should fire and give us our command
307
cmd = commands.get_cmd_object('foo')
308
self.assertEqual([('called', 'foo')], self.hook_calls)
309
self.assertIsInstance(cmd, self.ACommand)
310
del self.hook_calls[:]
311
# ask by a name that is supplied by a builtin - the hook should not
312
# fire and we still get our object.
313
commands.install_bzr_command_hooks()
314
cmd = commands.get_cmd_object('info')
315
self.assertNotEqual(None, cmd)
316
self.assertEqual(0, len(self.hook_calls))
318
def test_skipped_on_HelpCommandIndex_get_topics(self):
319
# The get_missing_command(cmd_name) hook is not fired when
320
# looking up help topics.
322
topic = commands.HelpCommandIndex()
323
topics = topic.get_topics('foo')
324
self.assertEqual([], self.hook_calls)
327
class TestListCommandHook(tests.TestCase):
329
def test_fires_on_all_command_names(self):
330
# The list_commands() hook fires when all_command_names() is invoked.
332
commands.install_bzr_command_hooks()
333
def list_my_commands(cmd_names):
334
hook_calls.append('called')
335
cmd_names.update(['foo', 'bar'])
337
commands.Command.hooks.install_named_hook(
338
"list_commands", list_my_commands, None)
339
# Get a command, which should not trigger the hook.
340
cmd = commands.get_cmd_object('info')
341
self.assertEqual([], hook_calls)
342
# Get all command classes (for docs and shell completion).
343
cmds = list(commands.all_command_names())
344
self.assertEqual(['called'], hook_calls)
345
self.assertSubset(['foo', 'bar'], cmds)
348
class TestDeprecations(tests.TestCase):
350
def test_shlex_split_unicode_deprecation(self):
351
res = self.applyDeprecated(
352
symbol_versioning.deprecated_in((2, 2, 0)),
353
commands.shlex_split_unicode, 'whatever')