Merge "Add support for retrieving instance-actions info"
This commit is contained in:
commit
655765a5ea
novaclient/v1_1/contrib
tests/v1_1
65
novaclient/v1_1/contrib/instance_action.py
Normal file
65
novaclient/v1_1/contrib/instance_action.py
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
# Copyright 2013 Rackspace Hosting
|
||||||
|
# All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import pprint
|
||||||
|
|
||||||
|
from novaclient import base
|
||||||
|
from novaclient import utils
|
||||||
|
|
||||||
|
|
||||||
|
class InstanceActionManager(base.ManagerWithFind):
|
||||||
|
resource_class = base.Resource
|
||||||
|
|
||||||
|
def get(self, server, request_id):
|
||||||
|
"""
|
||||||
|
Get details of an action performed on an instance.
|
||||||
|
|
||||||
|
:param request_id: The request_id of the action to get.
|
||||||
|
"""
|
||||||
|
return self._get("/servers/%s/os-instance-actions/%s" %
|
||||||
|
(base.getid(server), request_id), 'instanceAction')
|
||||||
|
|
||||||
|
def list(self, server):
|
||||||
|
"""
|
||||||
|
Get a list of actions performed on an server.
|
||||||
|
"""
|
||||||
|
return self._list('/servers/%s/os-instance-actions' %
|
||||||
|
base.getid(server), 'instanceActions')
|
||||||
|
|
||||||
|
|
||||||
|
@utils.arg('server',
|
||||||
|
metavar='<server>',
|
||||||
|
help='Name or UUID of the server to show an action for.')
|
||||||
|
@utils.arg('request_id',
|
||||||
|
metavar='<request_id>',
|
||||||
|
help='Request ID of the action to get.')
|
||||||
|
def do_instance_action(cs, args):
|
||||||
|
"""Show an action."""
|
||||||
|
server = utils.find_resource(cs.servers, args.server)
|
||||||
|
action_resource = cs.instance_action.get(server, args.request_id)
|
||||||
|
action = action_resource._info
|
||||||
|
if 'events' in action:
|
||||||
|
action['events'] = pprint.pformat(action['events'])
|
||||||
|
utils.print_dict(action)
|
||||||
|
|
||||||
|
|
||||||
|
@utils.arg('server',
|
||||||
|
metavar='<server>',
|
||||||
|
help='Name or UUID of the server to list actions for.')
|
||||||
|
def do_instance_action_list(cs, args):
|
||||||
|
"""List actions on a server."""
|
||||||
|
server = utils.find_resource(cs.servers, args.server)
|
||||||
|
actions = cs.instance_action.list(server)
|
||||||
|
utils.print_list(actions, ['Action', 'Request_ID', 'Message'])
|
41
tests/v1_1/contrib/test_instance_actions.py
Normal file
41
tests/v1_1/contrib/test_instance_actions.py
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
# Copyright 2013 Rackspace Hosting
|
||||||
|
# All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
from novaclient import extension
|
||||||
|
from novaclient.v1_1.contrib import instance_action
|
||||||
|
|
||||||
|
from tests import utils
|
||||||
|
from tests.v1_1.contrib import fakes
|
||||||
|
|
||||||
|
|
||||||
|
extensions = [
|
||||||
|
extension.Extension(instance_action.__name__.split(".")[-1],
|
||||||
|
instance_action),
|
||||||
|
]
|
||||||
|
cs = fakes.FakeClient(extensions=extensions)
|
||||||
|
|
||||||
|
|
||||||
|
class InstanceActionExtensionTests(utils.TestCase):
|
||||||
|
def test_list_instance_actions(self):
|
||||||
|
server_uuid = '1234'
|
||||||
|
cs.instance_action.list(server_uuid)
|
||||||
|
cs.assert_called('GET', '/servers/%s/os-instance-actions' %
|
||||||
|
server_uuid)
|
||||||
|
|
||||||
|
def test_get_instance_action(self):
|
||||||
|
server_uuid = '1234'
|
||||||
|
request_id = 'req-abcde12345'
|
||||||
|
cs.instance_action.get(server_uuid, request_id)
|
||||||
|
cs.assert_called('GET', '/servers/%s/os-instance-actions/%s' %
|
||||||
|
(server_uuid, request_id))
|
@ -1693,3 +1693,23 @@ class FakeHTTPClient(base_client.HTTPClient):
|
|||||||
|
|
||||||
def delete_servers_1234_os_volume_attachments_Work(self, **kw):
|
def delete_servers_1234_os_volume_attachments_Work(self, **kw):
|
||||||
return (200, {}, {})
|
return (200, {}, {})
|
||||||
|
|
||||||
|
def get_servers_1234_os_instance_actions(self, **kw):
|
||||||
|
return (200, {}, {"instanceActions":
|
||||||
|
[{"instance_uuid": "1234",
|
||||||
|
"user_id": "b968c25e04ab405f9fe4e6ca54cce9a5",
|
||||||
|
"start_time": "2013-03-25T13:45:09.000000",
|
||||||
|
"request_id": "req-abcde12345",
|
||||||
|
"action": "create",
|
||||||
|
"message": None,
|
||||||
|
"project_id": "04019601fe3648c0abd4f4abfb9e6106"}]})
|
||||||
|
|
||||||
|
def get_servers_1234_os_instance_actions_req_abcde12345(self, **kw):
|
||||||
|
return (200, {}, {"instanceAction":
|
||||||
|
{"instance_uuid": "1234",
|
||||||
|
"user_id": "b968c25e04ab405f9fe4e6ca54cce9a5",
|
||||||
|
"start_time": "2013-03-25T13:45:09.000000",
|
||||||
|
"request_id": "req-abcde12345",
|
||||||
|
"action": "create",
|
||||||
|
"message": None,
|
||||||
|
"project_id": "04019601fe3648c0abd4f4abfb9e6106"}})
|
||||||
|
@ -1276,3 +1276,12 @@ class ShellTest(utils.TestCase):
|
|||||||
self.run_command('volume-detach sample-server Work')
|
self.run_command('volume-detach sample-server Work')
|
||||||
self.assert_called('DELETE',
|
self.assert_called('DELETE',
|
||||||
'/servers/1234/os-volume_attachments/Work')
|
'/servers/1234/os-volume_attachments/Work')
|
||||||
|
|
||||||
|
def test_instance_action_list(self):
|
||||||
|
self.run_command('instance-action-list sample-server')
|
||||||
|
self.assert_called('GET', '/servers/1234/os-instance-actions')
|
||||||
|
|
||||||
|
def test_instance_action_get(self):
|
||||||
|
self.run_command('instance-action sample-server req-abcde12345')
|
||||||
|
self.assert_called('GET',
|
||||||
|
'/servers/1234/os-instance-actions/req-abcde12345')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user