Merge "Add --reason for disable service"

This commit is contained in:
Jenkins 2016-03-09 07:12:51 +00:00 committed by Gerrit Code Review
commit c8e4a1407f
4 changed files with 53 additions and 8 deletions

View File

@ -50,19 +50,24 @@ Set service command
.. program:: compute service set .. program:: compute service set
.. code:: bash .. code:: bash
os compute service list os compute service set
[--enable | --disable] [--enable | --disable]
[--disable-reason <reason>]
<host> <service> <host> <service>
.. _compute-service-set: .. _compute-service-set:
.. describe:: --enable .. option:: --enable
Enable service (default) Enable service (default)
.. describe:: --disable .. option:: --disable
Disable service Disable service
.. option:: --disable-reason <reason>
Reason for disabling the service (in quotes)
.. describe:: <host> .. describe:: <host>
Name of host Name of host

View File

@ -95,14 +95,24 @@ class SetService(command.Command):
dest="enabled", dest="enabled",
help="Disable a service", help="Disable a service",
action="store_false") action="store_false")
parser.add_argument(
"--disable-reason",
default=None,
metavar="<reason>",
help="Reason for disabling the service (in quotas)"
)
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
compute_client = self.app.client_manager.compute compute_client = self.app.client_manager.compute
cs = compute_client.services
if parsed_args.enabled: if not parsed_args.enabled:
action = compute_client.services.enable if parsed_args.disable_reason:
cs.disable_log_reason(parsed_args.host,
parsed_args.service,
parsed_args.disable_reason)
else:
cs.disable(parsed_args.host, parsed_args.service)
else: else:
action = compute_client.services.disable cs.enable(parsed_args.host, parsed_args.service)
action(parsed_args.host, parsed_args.service)

View File

@ -153,3 +153,29 @@ class TestServiceSet(TestService):
compute_fakes.service_binary, compute_fakes.service_binary,
) )
self.assertIsNone(result) self.assertIsNone(result)
def test_service_set_disable_with_reason(self):
reason = 'earthquake'
arglist = [
compute_fakes.service_host,
compute_fakes.service_binary,
'--disable',
'--disable-reason',
reason
]
verifylist = [
('host', compute_fakes.service_host),
('service', compute_fakes.service_binary),
('enabled', False),
('disable_reason', reason)
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args)
self.service_mock.disable_log_reason.assert_called_with(
compute_fakes.service_host,
compute_fakes.service_binary,
reason
)
self.assertIsNone(result)

View File

@ -0,0 +1,4 @@
---
features:
- |
Add support for the ``--disable-reason`` of ``service set`` command