From 21562eefbefc1ec943a0563d12b721bbb1db8e37 Mon Sep 17 00:00:00 2001 From: Ludovico Magnocavallo Date: Fri, 15 Dec 2023 20:20:49 +0100 Subject: [PATCH] don't fail quota fetch on deleted project (#1931) --- .../quota-monitoring/src/main.py | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/blueprints/cloud-operations/quota-monitoring/src/main.py b/blueprints/cloud-operations/quota-monitoring/src/main.py index e681afada9..27ade68a82 100755 --- a/blueprints/cloud-operations/quota-monitoring/src/main.py +++ b/blueprints/cloud-operations/quota-monitoring/src/main.py @@ -51,6 +51,10 @@ }]) +class NotFound(Exception): + pass + + class Quota(_Quota): 'Compute quota.' @@ -152,6 +156,9 @@ def fetch(request, delete=False): except json.JSONDecodeError as e: logging.critical(e) raise SystemExit(f'Error decoding response: {response.content}') + if response.status_code == 404: + raise NotFound( + f'Resource not found. Error: {rdata.get("error")} URL: {request.url}') if response.status_code != 200: logging.critical(rdata) error = rdata.get('error', {}) @@ -175,10 +182,14 @@ def get_quotas(project, region='global'): request = HTTPRequest(URL_PROJECT.format(project)) else: request = HTTPRequest(URL_REGION.format(project, region)) - resp = fetch(request) - ts = datetime.datetime.utcnow() - for quota in resp.get('quotas'): - yield Quota(project, region, ts, **quota) + try: + resp = fetch(request) + except NotFound as e: + logging.warn(e.args[0]) + else: + ts = datetime.datetime.utcnow() + for quota in resp.get('quotas'): + yield Quota(project, region, ts, **quota) @click.command()