Catch exceptions in AwsInstance and AzureInstance

This commit is contained in:
Shreya 2021-01-17 19:35:30 +05:30
parent 13af101c2a
commit 59383e7946
2 changed files with 6 additions and 5 deletions

View File

@ -45,7 +45,7 @@ class AwsInstance(CloudInstance):
self.account_id = self._extract_account_id( self.account_id = self._extract_account_id(
urllib.request.urlopen( urllib.request.urlopen(
AWS_LATEST_METADATA_URI_PREFIX + 'dynamic/instance-identity/document', timeout=2).read().decode()) AWS_LATEST_METADATA_URI_PREFIX + 'dynamic/instance-identity/document', timeout=2).read().decode())
except (urllib.error.URLError, IOError) as e: except (urllib.error.URLError, json.decoder.JSONDecodeError, IOError) as e:
logger.debug("Failed init of AwsInstance while getting dynamic instance data: {}".format(e)) logger.debug("Failed init of AwsInstance while getting dynamic instance data: {}".format(e))
@staticmethod @staticmethod

View File

@ -1,6 +1,7 @@
import logging import logging
import requests import requests
import simplejson
from common.cloud.environment_names import Environment from common.cloud.environment_names import Environment
from common.cloud.instance import CloudInstance from common.cloud.instance import CloudInstance
@ -41,10 +42,10 @@ class AzureInstance(CloudInstance):
# If not on cloud, the metadata URL is non-routable and the connection will fail. # If not on cloud, the metadata URL is non-routable and the connection will fail.
# If on AWS, should get 404 since the metadata service URL is different, so bool(response) will be false. # If on AWS, should get 404 since the metadata service URL is different, so bool(response) will be false.
if response: if response:
logger.debug("On Azure. Trying to parse metadata.") logger.debug("Trying to parse Azure metadata.")
self.try_parse_response(response) self.try_parse_response(response)
else: else:
logger.warning("On Azure, but metadata response not ok: {}".format(response.status_code)) logger.warning(f"On Azure, but metadata response not ok: {response.status_code}")
except requests.RequestException: except requests.RequestException:
logger.debug("Failed to get response from Azure metadata service: This instance is not on Azure.") logger.debug("Failed to get response from Azure metadata service: This instance is not on Azure.")
self.on_azure = False self.on_azure = False
@ -55,5 +56,5 @@ class AzureInstance(CloudInstance):
self.instance_name = response_data["compute"]["name"] self.instance_name = response_data["compute"]["name"]
self.instance_id = response_data["compute"]["vmId"] self.instance_id = response_data["compute"]["vmId"]
self.location = response_data["compute"]["location"] self.location = response_data["compute"]["location"]
except KeyError: except (KeyError, simplejson.errors.JSONDecodeError) as e:
logger.exception("Error while parsing response from Azure metadata service.") logger.exception(f"Error while parsing response from Azure metadata service: {e}")