205
206
# commands are registered).
206
207
# when they are simply created.
209
commands.install_bzr_command_hooks()
208
210
commands.Command.hooks.install_named_hook(
209
211
"extend_command", hook_calls.append, None)
210
212
# create a command, should not fire
271
274
self.assertIsInstance(hook_calls[0][1], builtins.cmd_info)
277
class TestGetMissingCommandHook(tests.TestCase):
279
def test_fires_on_get_cmd_object(self):
280
# The get_missing_command(cmd) hook fires when commands are delivered to the
283
class ACommand(commands.Command):
284
"""A sample command."""
285
def get_missing_cmd(cmd_name):
286
hook_calls.append(('called', cmd_name))
287
if cmd_name in ('foo', 'info'):
289
commands.Command.hooks.install_named_hook(
290
"get_missing_command", get_missing_cmd, None)
291
# create a command directly, should not fire
293
self.assertEqual([], hook_calls)
294
# ask by name, should fire and give us our command
295
cmd = commands.get_cmd_object('foo')
296
self.assertEqual([('called', 'foo')], hook_calls)
297
self.assertIsInstance(cmd, ACommand)
299
# ask by a name that is supplied by a builtin - the hook should not
300
# fire and we still get our object.
301
commands.install_bzr_command_hooks()
302
cmd = commands.get_cmd_object('info')
303
self.assertNotEqual(None, cmd)
304
self.assertEqual(0, len(hook_calls))
274
307
class TestListCommandHook(tests.TestCase):
276
309
def test_fires_on_all_command_names(self):
277
310
# The list_commands() hook fires when all_command_names() is invoked.
312
commands.install_bzr_command_hooks()
279
313
def list_my_commands(cmd_names):
280
314
hook_calls.append('called')
281
315
cmd_names.update(['foo', 'bar'])