Migrate to nova api version 2.1

The Nova v2 API code has been completely removed from Nova by
change[1]. Although Nova still supports v2 compatible API with the
legacy endpoint, it is better to switch to use Nova v2.1 in Heat.

This change sets version='2.1' when init novaclient
instance, then we can use novaclient v2 and will
use nova api v2.1.

[1] https://review.openstack.org/#/c/311653/

Change-Id: I428abb4ca05847da8ffc2da7157aa5c34263a205
Closes-Bug: #1588155
Partial-Bug: #1588171
This commit is contained in:
huangtianhua 2016-06-02 14:39:13 +08:00
parent 2b24b1c85b
commit a07dccebe0
4 changed files with 8 additions and 8 deletions

View File

@ -40,7 +40,7 @@ from heat.engine import constraints
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
NOVACLIENT_VERSION = "2" NOVA_API_VERSION = "2.1"
CLIENT_NAME = 'nova' CLIENT_NAME = 'nova'
@ -65,7 +65,7 @@ class NovaClientPlugin(client_plugin.ClientPlugin):
endpoint_type = self._get_client_option(CLIENT_NAME, 'endpoint_type') endpoint_type = self._get_client_option(CLIENT_NAME, 'endpoint_type')
management_url = self.url_for(service_type=self.COMPUTE, management_url = self.url_for(service_type=self.COMPUTE,
endpoint_type=endpoint_type) endpoint_type=endpoint_type)
extensions = nc.discover_extensions(NOVACLIENT_VERSION) extensions = nc.discover_extensions(NOVA_API_VERSION)
args = { args = {
'project_id': self.context.tenant_id, 'project_id': self.context.tenant_id,
@ -82,7 +82,7 @@ class NovaClientPlugin(client_plugin.ClientPlugin):
'insecure': self._get_client_option(CLIENT_NAME, 'insecure') 'insecure': self._get_client_option(CLIENT_NAME, 'insecure')
} }
client = nc.Client(NOVACLIENT_VERSION, **args) client = nc.Client(NOVA_API_VERSION, **args)
client.client.set_management_url(management_url) client.client.set_management_url(management_url)

View File

@ -49,7 +49,7 @@ class NovaClientPluginTest(NovaClientPluginTestCase):
ext_mock = self.patchobject(nc, 'discover_extensions') ext_mock = self.patchobject(nc, 'discover_extensions')
plugin = context.clients.client_plugin('nova') plugin = context.clients.client_plugin('nova')
client = plugin.client() client = plugin.client()
ext_mock.assert_called_once_with('2') ext_mock.assert_called_once_with('2.1')
self.assertIsNotNone(client.servers) self.assertIsNotNone(client.servers)
def test_get_ip(self): def test_get_ip(self):

View File

@ -24,9 +24,9 @@ from six.moves.urllib import parse as urlparse
from heat.tests import fakes from heat.tests import fakes
NOVACLIENT_VERSION = "2" NOVA_API_VERSION = "2.1"
Client = base_client.Client(NOVACLIENT_VERSION).__class__ Client = base_client.Client(NOVA_API_VERSION).__class__
def fake_exception(status_code=404, message=None, details=None): def fake_exception(status_code=404, message=None, details=None):

View File

@ -64,7 +64,7 @@ class ClientManager(object):
CINDERCLIENT_VERSION = '2' CINDERCLIENT_VERSION = '2'
HEATCLIENT_VERSION = '1' HEATCLIENT_VERSION = '1'
NOVACLIENT_VERSION = '2' NOVA_API_VERSION = '2.1'
CEILOMETER_VERSION = '2' CEILOMETER_VERSION = '2'
def __init__(self, conf): def __init__(self, conf):
@ -142,7 +142,7 @@ class ClientManager(object):
# Create our default Nova client to use in testing # Create our default Nova client to use in testing
return nova_client.Client( return nova_client.Client(
self.NOVACLIENT_VERSION, self.NOVA_API_VERSION,
*client_args, *client_args,
service_type='compute', service_type='compute',
endpoint_type='publicURL', endpoint_type='publicURL',