Support to set server state

When a server is unexpected state, OSC don't support reset
the server to active or error state, that's supported by
novaclient, and it's an important command for operators, the
patch implement this function.

Change-Id: I3e7800feb192832b0719ef9a353945beb6bfd509
Implements: blueprint server-reset-state
This commit is contained in:
Rui Chen 2016-05-28 18:55:50 +08:00
parent 7247707d34
commit 1a7284f63a
4 changed files with 81 additions and 0 deletions

View File

@ -559,6 +559,7 @@ Set server properties
--property <key=value> --property <key=value>
[--property <key=value>] ... [--property <key=value>] ...
--root-password --root-password
--state <state>
<server> <server>
.. option:: --name <new-name> .. option:: --name <new-name>
@ -574,6 +575,10 @@ Set server properties
Property to add/change for this server Property to add/change for this server
(repeat option to set multiple properties) (repeat option to set multiple properties)
.. option:: --state <state>
New server state (valid value: active, error)
.. describe:: <server> .. describe:: <server>
Server (name or ID) Server (name or ID)

View File

@ -1370,6 +1370,12 @@ class SetServer(command.Command):
help=_('Property to add/change for this server ' help=_('Property to add/change for this server '
'(repeat option to set multiple properties)'), '(repeat option to set multiple properties)'),
) )
parser.add_argument(
'--state',
metavar='<state>',
choices=['active', 'error'],
help=_('New server state (valid value: active, error)'),
)
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
@ -1389,6 +1395,9 @@ class SetServer(command.Command):
parsed_args.property, parsed_args.property,
) )
if parsed_args.state:
server.reset_state(state=parsed_args.state)
if parsed_args.root_password: if parsed_args.root_password:
p1 = getpass.getpass(_('New password: ')) p1 = getpass.getpass(_('New password: '))
p2 = getpass.getpass(_('Retype new password: ')) p2 = getpass.getpass(_('Retype new password: '))

View File

@ -1213,6 +1213,67 @@ class TestServerResume(TestServer):
self.run_method_with_servers('resume', 3) self.run_method_with_servers('resume', 3)
class TestServerSet(TestServer):
def setUp(self):
super(TestServerSet, self).setUp()
self.methods = {
'update': None,
'reset_state': None,
'change_password': None,
}
self.fake_servers = self.setup_servers_mock(2)
# Get the command object to test
self.cmd = server.SetServer(self.app, None)
def test_server_set_no_option(self):
arglist = [
'foo_vm'
]
verifylist = [
('server', 'foo_vm')
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args)
self.assertNotCalled(self.fake_servers[0].update)
self.assertNotCalled(self.fake_servers[0].reset_state)
self.assertNotCalled(self.fake_servers[0].change_password)
self.assertNotCalled(self.servers_mock.set_meta)
self.assertIsNone(result)
def test_server_set_with_state(self):
for index, state in enumerate(['active', 'error']):
arglist = [
'--state', state,
'foo_vm',
]
verifylist = [
('state', state),
('server', 'foo_vm'),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args)
self.fake_servers[index].reset_state.assert_called_once_with(
state=state)
self.assertIsNone(result)
def test_server_set_with_invalid_state(self):
arglist = [
'--state', 'foo_state',
'foo_vm',
]
verifylist = [
('state', 'foo_state'),
('server', 'foo_vm'),
]
self.assertRaises(utils.ParserException,
self.check_parser,
self.cmd, arglist, verifylist)
class TestServerShelve(TestServer): class TestServerShelve(TestServer):
def setUp(self): def setUp(self):

View File

@ -0,0 +1,6 @@
---
features:
- |
Add ``--state`` option to ``server set`` command to set the server to
active or error state.
[Blueprint `server-reset-state <https://blueprints.launchpad.net/python-openstackclient/+spec/server-reset-state>`_]