APIGateway - add passthroughBehaviour to the integration (#5142)
This commit is contained in:
parent
dbcee3c196
commit
416bef76e6
@ -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,
|
||||||
|
@ -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,
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user