diff --git a/changelogs/fragments/67247-fix-ec2_transit_gateway-retries.yaml b/changelogs/fragments/67247-fix-ec2_transit_gateway-retries.yaml new file mode 100644 index 00000000000..9e4d8e373b3 --- /dev/null +++ b/changelogs/fragments/67247-fix-ec2_transit_gateway-retries.yaml @@ -0,0 +1,2 @@ +bugfixes: + - ec2_transit_gateway - Use AWSRetry before ClientError is handled when describing transit gateways diff --git a/lib/ansible/modules/cloud/amazon/ec2_transit_gateway.py b/lib/ansible/modules/cloud/amazon/ec2_transit_gateway.py index d974bbd848e..69eadef0e87 100644 --- a/lib/ansible/modules/cloud/amazon/ec2_transit_gateway.py +++ b/lib/ansible/modules/cloud/amazon/ec2_transit_gateway.py @@ -313,7 +313,6 @@ class AnsibleEc2Tgw(object): return transit_gateway - @AWSRetry.exponential_backoff() def get_matching_tgw(self, tgw_id, description=None, skip_deleted=True): """ search for an existing tgw by either tgw_id or description :param tgw_id: The AWS id of the transit gateway @@ -326,7 +325,7 @@ class AnsibleEc2Tgw(object): filters = ansible_dict_to_boto3_filter_list({'transit-gateway-id': tgw_id}) try: - response = self._connection.describe_transit_gateways(Filters=filters) + response = AWSRetry.exponential_backoff()(self._connection.describe_transit_gateways)(Filters=filters) except (ClientError, BotoCoreError) as e: self._module.fail_json_aws(e)