nova/nova/tests/api/openstack/compute/plugins/v3/test_console_output.py

157 lines
5.8 KiB
Python

# Copyright 2011 Eldar Nugaev
# 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 string
import webob
from nova.compute import api as compute_api
from nova import exception
from nova.openstack.common import jsonutils
from nova import test
from nova.tests.api.openstack import fakes
def fake_get_console_output(self, _context, _instance, tail_length):
fixture = [str(i) for i in range(5)]
if tail_length is None:
pass
elif tail_length == 0:
fixture = []
else:
fixture = fixture[-int(tail_length):]
return '\n'.join(fixture)
def fake_get_console_output_not_ready(self, _context, _instance, tail_length):
raise exception.InstanceNotReady(instance_id=_instance["uuid"])
def fake_get_console_output_all_characters(self, _ctx, _instance, _tail_len):
return string.printable
def fake_get(self, context, instance_uuid):
return {'uuid': instance_uuid}
def fake_get_not_found(*args, **kwargs):
raise exception.InstanceNotFound(instance_id='')
class ConsoleOutputExtensionTest(test.NoDBTestCase):
application_type = "application/json"
def setUp(self):
super(ConsoleOutputExtensionTest, self).setUp()
self.stubs.Set(compute_api.API, 'get_console_output',
fake_get_console_output)
self.stubs.Set(compute_api.API, 'get', fake_get)
self.app = fakes.wsgi_app_v3(init_only=('servers', 'console-output'))
def _create_request(self, length_dict={}):
body = {'get_console_output': length_dict}
req = fakes.HTTPRequestV3.blank('/v3/servers/1/action')
req.method = "POST"
req.body = jsonutils.dumps(body)
req.headers["content-type"] = self.application_type
return req
def test_get_text_console_instance_action(self):
req = self._create_request(length_dict={})
res = req.get_response(self.app)
output = jsonutils.loads(res.body)
self.assertEqual(res.status_int, 200)
self.assertEqual(output, {'output': '0\n1\n2\n3\n4'})
def test_get_console_output_with_tail(self):
req = self._create_request(length_dict={'length': 3})
res = req.get_response(self.app)
output = jsonutils.loads(res.body)
self.assertEqual(res.status_int, 200)
self.assertEqual(output, {'output': '2\n3\n4'})
def test_get_console_output_with_length_as_str(self):
req = self._create_request(length_dict={'length': '3'})
res = req.get_response(self.app)
output = jsonutils.loads(res.body)
self.assertEqual(res.status_int, 200)
self.assertEqual(output, {'output': '2\n3\n4'})
def test_get_console_output_filtered_characters(self):
self.stubs.Set(compute_api.API, 'get_console_output',
fake_get_console_output_all_characters)
body = {'get_console_output': {}}
req = webob.Request.blank('/v3/servers/1/action')
req.method = "POST"
req.body = jsonutils.dumps(body)
req.headers["content-type"] = "application/json"
res = req.get_response(self.app)
output = jsonutils.loads(res.body)
self.assertEqual(res.status_int, 200)
expect = string.digits + string.letters + string.punctuation + ' \t\n'
self.assertEqual(output, {'output': expect})
def test_get_console_output_with_non_integer_length(self):
req = self._create_request(length_dict={'length': 'NaN'})
res = req.get_response(self.app)
self.assertEqual(res.status_int, 400)
def test_get_text_console_no_instance(self):
self.stubs.Set(compute_api.API, 'get', fake_get_not_found)
req = self._create_request(length_dict={})
res = req.get_response(self.app)
self.assertEqual(res.status_int, 404)
def test_get_text_console_bad_body(self):
body = {}
req = fakes.HTTPRequestV3.blank('/v3/servers/1/action')
req.method = "POST"
req.body = jsonutils.dumps(body)
req.headers["content-type"] = self.application_type
res = req.get_response(self.app)
self.assertEqual(res.status_int, 400)
def test_get_console_output_not_ready(self):
self.stubs.Set(compute_api.API, 'get_console_output',
fake_get_console_output_not_ready)
req = self._create_request(length_dict={'length': 3})
res = req.get_response(self.app)
self.assertEqual(res.status_int, 409)
def test_get_console_output_with_length_as_float(self):
req = self._create_request(length_dict={'length': 2.5})
res = req.get_response(self.app)
self.assertEqual(res.status_int, 400)
def test_get_console_output_not_implemented(self):
self.stubs.Set(compute_api.API, 'get_console_output',
fakes.fake_not_implemented)
req = self._create_request()
res = req.get_response(self.app)
self.assertEqual(res.status_int, 501)
def test_get_console_output_with_negative_length(self):
req = self._create_request(length_dict={'length': -1})
res = req.get_response(self.app)
self.assertEqual(res.status_int, 400)
def test_get_console_output_with_boolean_length(self):
req = self._create_request(length_dict={'length': True})
res = req.get_response(self.app)
self.assertEqual(res.status_int, 400)