Move nova flavor interactions to REST
One REST call is removed because python-novaclient made an extra get that we do not need to make. Change-Id: Idfc72a0f353c248e5749aea926031e70dcdf4f94
This commit is contained in:
parent
7d982af93e
commit
28fc6b02fa
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
upgrade:
|
||||||
|
- Nova flavor operations are now handled via REST calls
|
||||||
|
instead of via novaclient. There should be no noticable
|
||||||
|
difference.
|
@ -82,45 +82,6 @@ class ProjectUpdate(task_manager.Task):
|
|||||||
return client._project_manager.update(**self.args)
|
return client._project_manager.update(**self.args)
|
||||||
|
|
||||||
|
|
||||||
class FlavorList(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavors.list(**self.args)
|
|
||||||
|
|
||||||
|
|
||||||
class FlavorCreate(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavors.create(**self.args)
|
|
||||||
|
|
||||||
|
|
||||||
class FlavorDelete(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavors.delete(**self.args)
|
|
||||||
|
|
||||||
|
|
||||||
class FlavorGet(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavors.get(**self.args)
|
|
||||||
|
|
||||||
|
|
||||||
class FlavorListAccess(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavor_access.list(**self.args)
|
|
||||||
|
|
||||||
|
|
||||||
class FlavorAddAccess(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavor_access.add_tenant_access(
|
|
||||||
**self.args
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class FlavorRemoveAccess(task_manager.Task):
|
|
||||||
def main(self, client):
|
|
||||||
return client.nova_client.flavor_access.remove_tenant_access(
|
|
||||||
**self.args
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class ServerList(task_manager.Task):
|
class ServerList(task_manager.Task):
|
||||||
def main(self, client):
|
def main(self, client):
|
||||||
return client.nova_client.servers.list(**self.args)
|
return client.nova_client.servers.list(**self.args)
|
||||||
|
@ -1745,8 +1745,8 @@ class OpenStackCloud(_normalize.Normalizer):
|
|||||||
"""
|
"""
|
||||||
with _utils.shade_exceptions("Error fetching flavor list"):
|
with _utils.shade_exceptions("Error fetching flavor list"):
|
||||||
flavors = self._normalize_flavors(
|
flavors = self._normalize_flavors(
|
||||||
self.manager.submit_task(
|
self._compute_client.get(
|
||||||
_tasks.FlavorList(is_public=None)))
|
'/flavors/detail', params=dict(is_public='None')))
|
||||||
|
|
||||||
with _utils.shade_exceptions("Error fetching flavor extra specs"):
|
with _utils.shade_exceptions("Error fetching flavor extra specs"):
|
||||||
for flavor in flavors:
|
for flavor in flavors:
|
||||||
|
@ -1489,12 +1489,22 @@ class OperatorCloud(openstackcloud.OpenStackCloud):
|
|||||||
"""
|
"""
|
||||||
with _utils.shade_exceptions("Failed to create flavor {name}".format(
|
with _utils.shade_exceptions("Failed to create flavor {name}".format(
|
||||||
name=name)):
|
name=name)):
|
||||||
flavor = self.manager.submit_task(
|
payload = {
|
||||||
_tasks.FlavorCreate(name=name, ram=ram, vcpus=vcpus, disk=disk,
|
'disk': disk,
|
||||||
flavorid=flavorid, ephemeral=ephemeral,
|
'OS-FLV-EXT-DATA:ephemeral': ephemeral,
|
||||||
swap=swap, rxtx_factor=rxtx_factor,
|
'id': flavorid,
|
||||||
is_public=is_public)
|
'os-flavor-access:is_public': is_public,
|
||||||
)
|
'name': name,
|
||||||
|
'ram': ram,
|
||||||
|
'rxtx_factor': rxtx_factor,
|
||||||
|
'swap': swap,
|
||||||
|
'vcpus': vcpus,
|
||||||
|
}
|
||||||
|
if flavorid == 'auto':
|
||||||
|
payload['id'] = None
|
||||||
|
flavor = self._compute_client.post(
|
||||||
|
'/flavors',
|
||||||
|
json=dict(flavor=payload))
|
||||||
|
|
||||||
return self._normalize_flavor(flavor)
|
return self._normalize_flavor(flavor)
|
||||||
|
|
||||||
@ -1515,7 +1525,8 @@ class OperatorCloud(openstackcloud.OpenStackCloud):
|
|||||||
|
|
||||||
with _utils.shade_exceptions("Unable to delete flavor {name}".format(
|
with _utils.shade_exceptions("Unable to delete flavor {name}".format(
|
||||||
name=name_or_id)):
|
name=name_or_id)):
|
||||||
self.manager.submit_task(_tasks.FlavorDelete(flavor=flavor['id']))
|
self._compute_client.delete(
|
||||||
|
'/flavors/{id}'.format(id=flavor['id']))
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@ -1562,16 +1573,11 @@ class OperatorCloud(openstackcloud.OpenStackCloud):
|
|||||||
with _utils.shade_exceptions("Error trying to {action} access from "
|
with _utils.shade_exceptions("Error trying to {action} access from "
|
||||||
"flavor ID {flavor}".format(
|
"flavor ID {flavor}".format(
|
||||||
action=action, flavor=flavor_id)):
|
action=action, flavor=flavor_id)):
|
||||||
if action == 'add':
|
endpoint = '/flavors/{id}/action'.format(id=flavor_id)
|
||||||
self.manager.submit_task(
|
access = {'tenant': project_id}
|
||||||
_tasks.FlavorAddAccess(flavor=flavor_id,
|
access_key = '{action}TenantAccess'.format(action=action)
|
||||||
tenant=project_id)
|
|
||||||
)
|
self._compute_client.post(endpoint, json={access_key: access})
|
||||||
elif action == 'remove':
|
|
||||||
self.manager.submit_task(
|
|
||||||
_tasks.FlavorRemoveAccess(flavor=flavor_id,
|
|
||||||
tenant=project_id)
|
|
||||||
)
|
|
||||||
|
|
||||||
def add_flavor_access(self, flavor_id, project_id):
|
def add_flavor_access(self, flavor_id, project_id):
|
||||||
"""Grant access to a private flavor for a project/tenant.
|
"""Grant access to a private flavor for a project/tenant.
|
||||||
@ -1605,9 +1611,8 @@ class OperatorCloud(openstackcloud.OpenStackCloud):
|
|||||||
with _utils.shade_exceptions("Error trying to list access from "
|
with _utils.shade_exceptions("Error trying to list access from "
|
||||||
"flavor ID {flavor}".format(
|
"flavor ID {flavor}".format(
|
||||||
flavor=flavor_id)):
|
flavor=flavor_id)):
|
||||||
projects = self.manager.submit_task(
|
projects = self._compute_client.get(
|
||||||
_tasks.FlavorListAccess(flavor=flavor_id)
|
'/flavors/{id}/os-flavor-access'.format(id=flavor_id))
|
||||||
)
|
|
||||||
return _utils.normalize_flavor_accesses(projects)
|
return _utils.normalize_flavor_accesses(projects)
|
||||||
|
|
||||||
def create_role(self, name):
|
def create_role(self, name):
|
||||||
|
@ -321,3 +321,5 @@ class TestCreateServer(base.RequestsMockTestCase):
|
|||||||
'server-name', 'image-id', 'vanilla',
|
'server-name', 'image-id', 'vanilla',
|
||||||
nics=[{'net-id': 'some-network'}])
|
nics=[{'net-id': 'some-network'}])
|
||||||
mock_image.assert_called_once()
|
mock_image.assert_called_once()
|
||||||
|
|
||||||
|
self.assert_calls()
|
||||||
|
@ -37,11 +37,6 @@ class TestFlavors(base.RequestsMockTestCase):
|
|||||||
"id": None
|
"id": None
|
||||||
}}))
|
}}))
|
||||||
|
|
||||||
self.register_uri(
|
|
||||||
'GET', '{endpoint}/flavors/{id}'.format(
|
|
||||||
endpoint=fakes.ENDPOINT, id=fakes.FLAVOR_ID),
|
|
||||||
json={'flavor': fakes.FAKE_FLAVOR})
|
|
||||||
|
|
||||||
self.op_cloud.create_flavor(
|
self.op_cloud.create_flavor(
|
||||||
'vanilla', ram=65536, disk=1600, vcpus=24,
|
'vanilla', ram=65536, disk=1600, vcpus=24,
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user