139 lines
5.6 KiB
Python
139 lines
5.6 KiB
Python
|
# Copyright 2012 OpenStack Foundation
|
||
|
# 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 copy
|
||
|
from unittest import mock
|
||
|
|
||
|
from keystoneauth1 import session
|
||
|
from oslo_utils import uuidutils
|
||
|
|
||
|
import novaclient.api_versions
|
||
|
import novaclient.client
|
||
|
import novaclient.extension
|
||
|
from novaclient.tests.unit import utils
|
||
|
import novaclient.v2.client
|
||
|
|
||
|
|
||
|
class SessionClientTest(utils.TestCase):
|
||
|
|
||
|
def test_timings(self):
|
||
|
self.requests_mock.get('http://no.where')
|
||
|
|
||
|
client = novaclient.client.SessionClient(session=session.Session())
|
||
|
client.request("http://no.where", 'GET')
|
||
|
self.assertEqual(0, len(client.times))
|
||
|
|
||
|
client = novaclient.client.SessionClient(session=session.Session(),
|
||
|
timings=True)
|
||
|
client.request("http://no.where", 'GET')
|
||
|
self.assertEqual(1, len(client.times))
|
||
|
self.assertEqual('GET http://no.where', client.times[0][0])
|
||
|
|
||
|
def test_client_get_reset_timings_v2(self):
|
||
|
cs = novaclient.client.SessionClient(session=session.Session())
|
||
|
self.assertEqual(0, len(cs.get_timings()))
|
||
|
cs.times.append("somevalue")
|
||
|
self.assertEqual(1, len(cs.get_timings()))
|
||
|
self.assertEqual("somevalue", cs.get_timings()[0])
|
||
|
|
||
|
cs.reset_timings()
|
||
|
self.assertEqual(0, len(cs.get_timings()))
|
||
|
|
||
|
def test_global_id(self):
|
||
|
global_id = "req-%s" % uuidutils.generate_uuid()
|
||
|
self.requests_mock.get('http://no.where')
|
||
|
|
||
|
client = novaclient.client.SessionClient(session=session.Session(),
|
||
|
global_request_id=global_id)
|
||
|
client.request("http://no.where", 'GET')
|
||
|
headers = self.requests_mock.last_request.headers
|
||
|
self.assertEqual(headers['X-OpenStack-Request-ID'], global_id)
|
||
|
|
||
|
|
||
|
class ClientsUtilsTest(utils.TestCase):
|
||
|
|
||
|
@mock.patch("novaclient.client._discover_via_entry_points")
|
||
|
@mock.patch("novaclient.client._discover_via_python_path")
|
||
|
@mock.patch("novaclient.extension.Extension")
|
||
|
def test_discover_extensions_all(self, mock_extension,
|
||
|
mock_discover_via_python_path,
|
||
|
mock_discover_via_entry_points):
|
||
|
def make_gen(start, end):
|
||
|
def f(*args, **kwargs):
|
||
|
for i in range(start, end):
|
||
|
yield "name-%s" % i, i
|
||
|
return f
|
||
|
|
||
|
mock_discover_via_python_path.side_effect = make_gen(0, 3)
|
||
|
mock_discover_via_entry_points.side_effect = make_gen(3, 4)
|
||
|
|
||
|
version = novaclient.api_versions.APIVersion("2.0")
|
||
|
|
||
|
result = novaclient.client.discover_extensions(version)
|
||
|
|
||
|
self.assertEqual([mock.call("name-%s" % i, i) for i in range(0, 4)],
|
||
|
mock_extension.call_args_list)
|
||
|
mock_discover_via_python_path.assert_called_once_with()
|
||
|
mock_discover_via_entry_points.assert_called_once_with()
|
||
|
self.assertEqual([mock_extension()] * 4, result)
|
||
|
|
||
|
@mock.patch("novaclient.client.warnings")
|
||
|
def test__check_arguments(self, mock_warnings):
|
||
|
release = "Coolest"
|
||
|
|
||
|
# no reference
|
||
|
novaclient.client._check_arguments({}, release=release,
|
||
|
deprecated_name="foo")
|
||
|
self.assertFalse(mock_warnings.warn.called)
|
||
|
novaclient.client._check_arguments({}, release=release,
|
||
|
deprecated_name="foo",
|
||
|
right_name="bar")
|
||
|
self.assertFalse(mock_warnings.warn.called)
|
||
|
|
||
|
# with alternative
|
||
|
original_kwargs = {"foo": "text"}
|
||
|
actual_kwargs = copy.copy(original_kwargs)
|
||
|
self.assertEqual(original_kwargs, actual_kwargs)
|
||
|
novaclient.client._check_arguments(actual_kwargs, release=release,
|
||
|
deprecated_name="foo",
|
||
|
right_name="bar")
|
||
|
self.assertNotEqual(original_kwargs, actual_kwargs)
|
||
|
self.assertEqual({"bar": original_kwargs["foo"]}, actual_kwargs)
|
||
|
self.assertTrue(mock_warnings.warn.called)
|
||
|
|
||
|
mock_warnings.warn.reset_mock()
|
||
|
|
||
|
# without alternative
|
||
|
original_kwargs = {"foo": "text"}
|
||
|
actual_kwargs = copy.copy(original_kwargs)
|
||
|
self.assertEqual(original_kwargs, actual_kwargs)
|
||
|
novaclient.client._check_arguments(actual_kwargs, release=release,
|
||
|
deprecated_name="foo")
|
||
|
self.assertNotEqual(original_kwargs, actual_kwargs)
|
||
|
self.assertEqual({}, actual_kwargs)
|
||
|
self.assertTrue(mock_warnings.warn.called)
|
||
|
|
||
|
|
||
|
class ClientTest(utils.TestCase):
|
||
|
|
||
|
def test_logger(self):
|
||
|
client = novaclient.client.Client('2.1', logger=mock.sentinel.logger)
|
||
|
self.assertEqual(mock.sentinel.logger, client.logger)
|
||
|
self.assertEqual(mock.sentinel.logger, client.client.logger)
|
||
|
client = novaclient.client.Client('2.1')
|
||
|
self.assertEqual('novaclient.v2.client', client.logger.name)
|
||
|
self.assertIsNotNone(client.client.logger)
|
||
|
self.assertEqual('novaclient.v2.client', client.client.logger.name)
|