APIGateway - add passthroughBehaviour to the integration (#5142)

This commit is contained in:
Cesar Alvernaz 2022-05-19 11:16:33 +01:00 committed by GitHub
parent dbcee3c196
commit 416bef76e6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 25 additions and 2 deletions

View File

@ -126,6 +126,8 @@ class Integration(BaseModel, dict):
uri, uri,
http_method, http_method,
request_templates=None, request_templates=None,
passthrough_behavior="WHEN_NO_MATCH",
cache_key_parameters=None,
tls_config=None, tls_config=None,
cache_namespace=None, cache_namespace=None,
timeout_in_millis=None, timeout_in_millis=None,
@ -133,7 +135,9 @@ class Integration(BaseModel, dict):
super().__init__() super().__init__()
self["type"] = integration_type self["type"] = integration_type
self["uri"] = uri self["uri"] = uri
self["httpMethod"] = http_method self["httpMethod"] = http_method if integration_type != "MOCK" else None
self["passthroughBehavior"] = passthrough_behavior
self["cacheKeyParameters"] = cache_key_parameters or []
self["requestTemplates"] = request_templates self["requestTemplates"] = request_templates
# self["integrationResponses"] = {"200": IntegrationResponse(200)} # commented out (tf-compat) # self["integrationResponses"] = {"200": IntegrationResponse(200)} # commented out (tf-compat)
self[ self[
@ -369,6 +373,7 @@ class Resource(CloudFormationModel):
integration_type, integration_type,
uri, uri,
request_templates=None, request_templates=None,
passthrough_behavior=None,
integration_method=None, integration_method=None,
tls_config=None, tls_config=None,
cache_namespace=None, cache_namespace=None,
@ -380,6 +385,7 @@ class Resource(CloudFormationModel):
uri, uri,
integration_method, integration_method,
request_templates=request_templates, request_templates=request_templates,
passthrough_behavior=passthrough_behavior,
tls_config=tls_config, tls_config=tls_config,
cache_namespace=cache_namespace, cache_namespace=cache_namespace,
timeout_in_millis=timeout_in_millis, timeout_in_millis=timeout_in_millis,
@ -1564,6 +1570,7 @@ class APIGatewayBackend(BaseBackend):
integration_method=None, integration_method=None,
credentials=None, credentials=None,
request_templates=None, request_templates=None,
passthrough_behavior=None,
tls_config=None, tls_config=None,
cache_namespace=None, cache_namespace=None,
timeout_in_millis=None, timeout_in_millis=None,
@ -1604,6 +1611,7 @@ class APIGatewayBackend(BaseBackend):
uri, uri,
integration_method=integration_method, integration_method=integration_method,
request_templates=request_templates, request_templates=request_templates,
passthrough_behavior=passthrough_behavior,
tls_config=tls_config, tls_config=tls_config,
cache_namespace=cache_namespace, cache_namespace=cache_namespace,
timeout_in_millis=timeout_in_millis, timeout_in_millis=timeout_in_millis,

View File

@ -442,6 +442,7 @@ class APIGatewayResponse(BaseResponse):
uri = self._get_param("uri") uri = self._get_param("uri")
credentials = self._get_param("credentials") credentials = self._get_param("credentials")
request_templates = self._get_param("requestTemplates") request_templates = self._get_param("requestTemplates")
passthrough_behavior = self._get_param("passthroughBehavior")
tls_config = self._get_param("tlsConfig") tls_config = self._get_param("tlsConfig")
cache_namespace = self._get_param("cacheNamespace") cache_namespace = self._get_param("cacheNamespace")
timeout_in_millis = self._get_param("timeoutInMillis") timeout_in_millis = self._get_param("timeoutInMillis")
@ -460,6 +461,7 @@ class APIGatewayResponse(BaseResponse):
credentials=credentials, credentials=credentials,
integration_method=integration_http_method, integration_method=integration_http_method,
request_templates=request_templates, request_templates=request_templates,
passthrough_behavior=passthrough_behavior,
tls_config=tls_config, tls_config=tls_config,
cache_namespace=cache_namespace, cache_namespace=cache_namespace,
timeout_in_millis=timeout_in_millis, timeout_in_millis=timeout_in_millis,

View File

@ -517,6 +517,7 @@ def test_integrations():
resourceId=root_id, resourceId=root_id,
httpMethod="GET", httpMethod="GET",
type="HTTP", type="HTTP",
passthroughBehavior="WHEN_NO_TEMPLATES",
uri="http://httpbin.org/robots.txt", uri="http://httpbin.org/robots.txt",
integrationHttpMethod="POST", integrationHttpMethod="POST",
) )
@ -529,6 +530,8 @@ def test_integrations():
"httpMethod": "POST", "httpMethod": "POST",
"type": "HTTP", "type": "HTTP",
"uri": "http://httpbin.org/robots.txt", "uri": "http://httpbin.org/robots.txt",
"passthroughBehavior": "WHEN_NO_TEMPLATES",
"cacheKeyParameters": [],
} }
) )
@ -544,6 +547,8 @@ def test_integrations():
"httpMethod": "POST", "httpMethod": "POST",
"type": "HTTP", "type": "HTTP",
"uri": "http://httpbin.org/robots.txt", "uri": "http://httpbin.org/robots.txt",
"passthroughBehavior": "WHEN_NO_TEMPLATES",
"cacheKeyParameters": [],
} }
) )
@ -554,7 +559,13 @@ def test_integrations():
response["resourceMethods"]["GET"]["httpMethod"].should.equal("GET") response["resourceMethods"]["GET"]["httpMethod"].should.equal("GET")
response["resourceMethods"]["GET"]["authorizationType"].should.equal("none") response["resourceMethods"]["GET"]["authorizationType"].should.equal("none")
response["resourceMethods"]["GET"]["methodIntegration"].should.equal( response["resourceMethods"]["GET"]["methodIntegration"].should.equal(
{"httpMethod": "POST", "type": "HTTP", "uri": "http://httpbin.org/robots.txt"} {
"httpMethod": "POST",
"type": "HTTP",
"uri": "http://httpbin.org/robots.txt",
"cacheKeyParameters": [],
"passthroughBehavior": "WHEN_NO_TEMPLATES",
}
) )
client.delete_integration(restApiId=api_id, resourceId=root_id, httpMethod="GET") client.delete_integration(restApiId=api_id, resourceId=root_id, httpMethod="GET")
@ -584,6 +595,7 @@ def test_integrations():
type="HTTP", type="HTTP",
uri=test_uri, uri=test_uri,
requestTemplates=templates, requestTemplates=templates,
passthroughBehavior="WHEN_NO_MATCH",
integrationHttpMethod="POST", integrationHttpMethod="POST",
timeoutInMillis=29000, timeoutInMillis=29000,
) )
@ -593,6 +605,7 @@ def test_integrations():
) )
response["uri"].should.equal(test_uri) response["uri"].should.equal(test_uri)
response["requestTemplates"].should.equal(templates) response["requestTemplates"].should.equal(templates)
response["passthroughBehavior"].should.equal("WHEN_NO_MATCH")
response.should.have.key("timeoutInMillis").equals(29000) response.should.have.key("timeoutInMillis").equals(29000)