Cloudformation: Fix - validate template yml fixes

This change fixes:
* Replace call to non-existent exception yaml.ParserError
* Catches yaml scanner error for valid json with tabs
* Supply yaml loader to ensure yaml loading throws exception validly for json with tabs and doesn't try to load the json incorrectly
This commit is contained in:
Shane 2020-06-30 22:35:47 +01:00
parent 73813460b6
commit 0f062f68ff
No known key found for this signature in database
GPG Key ID: 439BE3F7ABFB2A56
2 changed files with 21 additions and 2 deletions

View File

@ -365,8 +365,8 @@ class CloudFormationResponse(BaseResponse):
except (ValueError, KeyError): except (ValueError, KeyError):
pass pass
try: try:
description = yaml.load(template_body)["Description"] description = yaml.load(template_body, Loader=yaml.Loader)["Description"]
except (yaml.ParserError, KeyError): except (yaml.parser.ParserError, yaml.scanner.ScannerError, KeyError):
pass pass
template = self.response_template(VALIDATE_STACK_RESPONSE_TEMPLATE) template = self.response_template(VALIDATE_STACK_RESPONSE_TEMPLATE)
return template.render(description=description) return template.render(description=description)

View File

@ -40,6 +40,16 @@ json_template = {
}, },
} }
json_valid_template_with_tabs = """
{
\t"AWSTemplateFormatVersion": "2010-09-09",
\t"Description": "Stack 2",
\t"Resources": {
\t\t"Queue": {"Type": "AWS::SQS::Queue", "Properties": {"VisibilityTimeout": 60}}
\t}
}
"""
# One resource is required # One resource is required
json_bad_template = {"AWSTemplateFormatVersion": "2010-09-09", "Description": "Stack 1"} json_bad_template = {"AWSTemplateFormatVersion": "2010-09-09", "Description": "Stack 1"}
@ -56,6 +66,15 @@ def test_boto3_json_validate_successful():
assert response["ResponseMetadata"]["HTTPStatusCode"] == 200 assert response["ResponseMetadata"]["HTTPStatusCode"] == 200
@mock_cloudformation
def test_boto3_json_with_tabs_validate_successful():
cf_conn = boto3.client("cloudformation", region_name="us-east-1")
response = cf_conn.validate_template(TemplateBody=json_valid_template_with_tabs)
assert response["Description"] == "Stack 2"
assert response["Parameters"] == []
assert response["ResponseMetadata"]["HTTPStatusCode"] == 200
@mock_cloudformation @mock_cloudformation
def test_boto3_json_invalid_missing_resource(): def test_boto3_json_invalid_missing_resource():
cf_conn = boto3.client("cloudformation", region_name="us-east-1") cf_conn = boto3.client("cloudformation", region_name="us-east-1")