Add heatclient support

In support of https://github.com/ansible/ansible-modules-core/pull/2036
add at least a heat client constructor.

Also, check it out - heatclient doesn't support Session auth. Until it
does, we're not going to support advanced things like overriding SSL
args.

Change-Id: I488fde4abe5abc1c58515cf77d08644b49eb5ba6
This commit is contained in:
Monty Taylor 2015-09-12 10:07:24 +02:00 committed by David Shrewsbury
parent 3a6b90a4e1
commit 7aa043ec87
3 changed files with 37 additions and 0 deletions

View File

@ -18,5 +18,6 @@ python-troveclient>=1.2.0
python-ironicclient>=0.9.0 python-ironicclient>=0.9.0
python-swiftclient>=2.5.0 python-swiftclient>=2.5.0
python-designateclient>=1.3.0 python-designateclient>=1.3.0
python-heatclient>=0.3.0
dogpile.cache>=0.5.3 dogpile.cache>=0.5.3

View File

@ -29,6 +29,8 @@ import glanceclient
import glanceclient.exc import glanceclient.exc
from glanceclient.common import utils as glance_utils from glanceclient.common import utils as glance_utils
import ipaddress import ipaddress
from heatclient import client as heat_client
from heatclient.common import template_utils
from ironicclient import client as ironic_client from ironicclient import client as ironic_client
from ironicclient import exceptions as ironic_exceptions from ironicclient import exceptions as ironic_exceptions
import jsonpatch import jsonpatch
@ -316,6 +318,7 @@ class OpenStackCloud(object):
self._designate_client = None self._designate_client = None
self._glance_client = None self._glance_client = None
self._glance_endpoint = None self._glance_endpoint = None
self._heat_client = None
self._ironic_client = None self._ironic_client = None
self._keystone_client = None self._keystone_client = None
self._neutron_client = None self._neutron_client = None
@ -695,6 +698,24 @@ class OpenStackCloud(object):
endpoint=endpoint) endpoint=endpoint)
return self._glance_client return self._glance_client
@property
def heat_client(self):
if self._heat_client is None:
self._heat_client = self._get_client(
'orchestration', heat_client.Client)
return self._heat_client
def get_template_contents(
self, template_file=None, template_url=None,
template_object=None, files=None):
try:
return template_utils.get_template_contents(
template_file=template_file, template_url=template_url,
template_object=template_object, files=files)
except Exception as e:
raise OpenStackCloudException(
"Error in processing template files: %s" % str(e))
@property @property
def swift_client(self): def swift_client(self):
if self._swift_client is None: if self._swift_client is None:

View File

@ -15,6 +15,7 @@
import mock import mock
import glanceclient import glanceclient
from heatclient import client as heat_client
from keystoneclient.v2_0 import client as k2_client from keystoneclient.v2_0 import client as k2_client
from keystoneclient.v3 import client as k3_client from keystoneclient.v3 import client as k3_client
from neutronclient.common import exceptions as n_exc from neutronclient.common import exceptions as n_exc
@ -111,6 +112,20 @@ class TestShade(base.TestCase):
service_type='image', session=mock.ANY, service_type='image', session=mock.ANY,
) )
@mock.patch.object(shade.OpenStackCloud, 'keystone_session')
@mock.patch.object(heat_client, 'Client')
def test_heat_args(self, mock_client, mock_keystone_session):
mock_keystone_session.return_value = None
self.cloud.heat_client
mock_client.assert_called_with(
endpoint_type='public',
region_name='',
service_name=None,
service_type='orchestration',
session=mock.ANY,
version='1'
)
@mock.patch.object(shade.OpenStackCloud, 'search_subnets') @mock.patch.object(shade.OpenStackCloud, 'search_subnets')
def test_get_subnet(self, mock_search): def test_get_subnet(self, mock_search):
subnet = dict(id='123', name='mickey') subnet = dict(id='123', name='mickey')