bug fix: ensure resource class instead of getting it.

Before, we used "get" to make sure the resource class exist in our
enviroment. If we customerize a new resource class like
"CUSTOM_AICHIP", the "get" function will return a 404 without throwing
out an exception, the ensure_resource_class will not be called. So we
will fail to create a new resource class.

This patch fixes this bug.

Change-Id: I203fe44ab9996c6c1e0e5ed85655674ed1119824
This commit is contained in:
HeyIns 2019-10-11 22:50:49 -07:00 committed by Xinran WANG
parent 1e08be3dc2
commit 82985ed9b9
2 changed files with 9 additions and 5 deletions

View File

@ -28,6 +28,7 @@ PLACEMENT_CLIENT_SEMAPHORE = 'placement_client'
class PlacementClient(object):
"""Client class for reporting to placement."""
def __init__(self):
self._client = utils.get_sdk_adapter('placement')
@ -226,6 +227,12 @@ class PlacementClient(object):
}
LOG.error(msg, args)
raise exception.InvalidResourceClass(resource_class=name)
elif resp.status_code == 204:
LOG.info("Resource class %(rc_name)s already exists",
{"rc_name": name})
elif resp.status_code == 201:
LOG.info("Successfully created resource class %(rc_name).", {
"rc_name", name})
def _get_providers_in_tree(self, context, uuid):
"""Queries the placement API for a list of the resource providers in

View File

@ -386,12 +386,9 @@ class ConductorManager(object):
def provider_report(self, context, name, resource_class, traits, total,
parent):
try:
self.placement_client.get("/resource_classes/%s" %
resource_class,
version='1.26')
self.placement_client.ensure_resource_classes(
context, [resource_class])
except Exception as e:
self.placement_client.ensure_resource_classes(context,
[resource_class])
LOG.error("Error, could not access resource_classes."
"Details: %(info)s", {"info": e})