2020-05-03 03:01:46 +00:00
import json
2016-09-13 11:44:17 +00:00
2016-03-01 17:03:59 +00:00
import boto3
from freezegun import freeze_time
2016-09-13 11:44:17 +00:00
from botocore . exceptions import ClientError
2016-03-01 17:03:59 +00:00
2023-06-07 09:46:18 +00:00
from moto import mock_apigateway , mock_cognitoidp , settings
2022-08-13 09:49:43 +00:00
from moto . core import DEFAULT_ACCOUNT_ID as ACCOUNT_ID
2020-10-06 05:54:49 +00:00
import pytest
2016-03-01 17:03:59 +00:00
2022-11-21 21:46:07 +00:00
from tests import DEFAULT_ACCOUNT_ID
2016-03-01 17:03:59 +00:00
@freeze_time ( " 2015-01-01 " )
@mock_apigateway
def test_create_and_get_rest_api ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2016-03-01 17:03:59 +00:00
2022-11-21 21:46:07 +00:00
response = client . create_rest_api (
name = " my_api " , description = " this is my api " , disableExecuteApiEndpoint = True
)
2019-10-31 15:44:26 +00:00
api_id = response [ " id " ]
2016-03-01 17:03:59 +00:00
2019-10-31 15:44:26 +00:00
response = client . get_rest_api ( restApiId = api_id )
2016-03-01 17:03:59 +00:00
2019-10-31 15:44:26 +00:00
response . pop ( " ResponseMetadata " )
response . pop ( " createdDate " )
2023-06-07 09:46:18 +00:00
assert response == {
" id " : api_id ,
" name " : " my_api " ,
" description " : " this is my api " ,
" version " : " V1 " ,
" binaryMediaTypes " : [ ] ,
" apiKeySource " : " HEADER " ,
" endpointConfiguration " : { " types " : [ " EDGE " ] } ,
" tags " : { } ,
" disableExecuteApiEndpoint " : True ,
}
2016-03-01 17:03:59 +00:00
2021-05-23 16:09:02 +00:00
@mock_apigateway
2021-09-18 20:17:42 +00:00
def test_update_rest_api ( ) :
2021-05-23 16:09:02 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
patchOperations = [
{ " op " : " replace " , " path " : " /name " , " value " : " new-name " } ,
{ " op " : " replace " , " path " : " /description " , " value " : " new-description " } ,
{ " op " : " replace " , " path " : " /apiKeySource " , " value " : " AUTHORIZER " } ,
{ " op " : " replace " , " path " : " /binaryMediaTypes " , " value " : " image/jpeg " } ,
{ " op " : " replace " , " path " : " /disableExecuteApiEndpoint " , " value " : " True " } ,
2023-02-22 22:42:13 +00:00
{
" op " : " replace " ,
" path " : " /policy " ,
" value " : ' { " Version " : " 2012-10-17 " , " Statement " : [ { " Effect " : " Allow " , " Principal " : " * " , " Action " : '
' " execute-api:Invoke " , " Resource " : [ " execute-api:/* " ]}]} ' ,
} ,
2021-05-23 16:09:02 +00:00
]
response = client . update_rest_api ( restApiId = api_id , patchOperations = patchOperations )
response . pop ( " ResponseMetadata " )
response . pop ( " createdDate " )
response . pop ( " binaryMediaTypes " )
2023-06-07 09:46:18 +00:00
assert response == {
" id " : api_id ,
" name " : " new-name " ,
" version " : " V1 " ,
" description " : " new-description " ,
" apiKeySource " : " AUTHORIZER " ,
" policy " : ' { " Version " : " 2012-10-17 " , " Statement " : [ { " Effect " : " Allow " , " Principal " : " * " , " Action " : '
' " execute-api:Invoke " , " Resource " : [ " execute-api:/* " ]}]} ' ,
" endpointConfiguration " : { " types " : [ " EDGE " ] } ,
" tags " : { } ,
" disableExecuteApiEndpoint " : True ,
}
2021-05-23 16:09:02 +00:00
# should fail with wrong apikeysoruce
patchOperations = [
{ " op " : " replace " , " path " : " /apiKeySource " , " value " : " Wrong-value-AUTHORIZER " }
]
with pytest . raises ( ClientError ) as ex :
2023-06-07 09:46:18 +00:00
client . update_rest_api ( restApiId = api_id , patchOperations = patchOperations )
err = ex . value . response [ " Error " ]
assert (
err [ " Message " ]
== " 1 validation error detected: Value ' Wrong-value-AUTHORIZER ' at ' createRestApiInput.apiKeySource ' failed to satisfy constraint: Member must satisfy enum value set: [AUTHORIZER, HEADER] "
2021-05-23 16:09:02 +00:00
)
2023-06-07 09:46:18 +00:00
assert err [ " Code " ] == " ValidationException "
2021-05-23 16:09:02 +00:00
@mock_apigateway
2021-09-18 20:17:42 +00:00
def test_update_rest_api_invalid_api_id ( ) :
2021-05-23 16:09:02 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
patchOperations = [
{ " op " : " replace " , " path " : " /apiKeySource " , " value " : " AUTHORIZER " }
]
with pytest . raises ( ClientError ) as ex :
client . update_rest_api ( restApiId = " api_id " , patchOperations = patchOperations )
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
2021-05-23 16:09:02 +00:00
2021-09-18 20:17:42 +00:00
@mock_apigateway
def test_update_rest_api_operation_add_remove ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
patchOperations = [
{ " op " : " add " , " path " : " /binaryMediaTypes " , " value " : " image/png " } ,
{ " op " : " add " , " path " : " /binaryMediaTypes " , " value " : " image/jpeg " } ,
]
response = client . update_rest_api ( restApiId = api_id , patchOperations = patchOperations )
2023-06-07 09:46:18 +00:00
assert response [ " binaryMediaTypes " ] == [ " image/png " , " image/jpeg " ]
assert response [ " description " ] == " this is my api "
2021-09-18 20:17:42 +00:00
patchOperations = [
{ " op " : " remove " , " path " : " /binaryMediaTypes " , " value " : " image/png " } ,
{ " op " : " remove " , " path " : " /description " } ,
]
response = client . update_rest_api ( restApiId = api_id , patchOperations = patchOperations )
2023-06-07 09:46:18 +00:00
assert response [ " binaryMediaTypes " ] == [ " image/jpeg " ]
assert response [ " description " ] == " "
2021-09-18 20:17:42 +00:00
2016-03-01 17:03:59 +00:00
@mock_apigateway
def test_list_and_delete_apis ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2016-03-01 17:03:59 +00:00
2019-10-31 15:44:26 +00:00
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
client . create_rest_api ( name = " my_api2 " , description = " this is my api2 " )
2016-03-01 17:03:59 +00:00
response = client . get_rest_apis ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 2
2016-03-01 17:03:59 +00:00
2019-10-31 15:44:26 +00:00
client . delete_rest_api ( restApiId = api_id )
2016-03-01 17:03:59 +00:00
response = client . get_rest_apis ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 1
2016-03-01 23:50:06 +00:00
2020-02-03 16:21:22 +00:00
@mock_apigateway
def test_create_rest_api_with_tags ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api (
name = " my_api " , description = " this is my api " , tags = { " MY_TAG1 " : " MY_VALUE1 " }
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
assert " tags " in response
2023-06-07 09:46:18 +00:00
assert response [ " tags " ] == { " MY_TAG1 " : " MY_VALUE1 " }
2020-02-03 16:21:22 +00:00
2020-04-25 08:27:59 +00:00
@mock_apigateway
def test_create_rest_api_with_policy ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-04-25 16:24:54 +00:00
policy = ' { " Version " : " 2012-10-17 " , " Statement " : []} '
2020-04-25 08:27:59 +00:00
response = client . create_rest_api (
2020-04-25 16:24:54 +00:00
name = " my_api " , description = " this is my api " , policy = policy
2020-04-25 08:27:59 +00:00
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
assert " policy " in response
2023-06-07 09:46:18 +00:00
assert response [ " policy " ] == policy
2020-04-25 08:27:59 +00:00
2020-02-03 16:21:22 +00:00
@mock_apigateway
def test_create_rest_api_invalid_apikeysource ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-02-03 16:21:22 +00:00
client . create_rest_api (
name = " my_api " ,
description = " this is my api " ,
apiKeySource = " not a valid api key source " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " ValidationException "
2020-02-03 16:21:22 +00:00
@mock_apigateway
def test_create_rest_api_valid_apikeysources ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
# 1. test creating rest api with HEADER apiKeySource
response = client . create_rest_api (
2022-03-10 14:39:59 +00:00
name = " my_api " , description = " this is my api " , apiKeySource = " HEADER "
2020-02-03 16:21:22 +00:00
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
2023-06-07 09:46:18 +00:00
assert response [ " apiKeySource " ] == " HEADER "
2020-02-03 16:21:22 +00:00
# 2. test creating rest api with AUTHORIZER apiKeySource
response = client . create_rest_api (
2022-03-10 14:39:59 +00:00
name = " my_api2 " , description = " this is my api " , apiKeySource = " AUTHORIZER "
2020-02-03 16:21:22 +00:00
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
2023-06-07 09:46:18 +00:00
assert response [ " apiKeySource " ] == " AUTHORIZER "
2020-02-03 16:21:22 +00:00
@mock_apigateway
def test_create_rest_api_invalid_endpointconfiguration ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-02-03 16:21:22 +00:00
client . create_rest_api (
name = " my_api " ,
description = " this is my api " ,
endpointConfiguration = { " types " : [ " INVALID " ] } ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " ValidationException "
2020-02-03 16:21:22 +00:00
@mock_apigateway
def test_create_rest_api_valid_endpointconfigurations ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
# 1. test creating rest api with PRIVATE endpointConfiguration
response = client . create_rest_api (
name = " my_api " ,
description = " this is my api " ,
endpointConfiguration = { " types " : [ " PRIVATE " ] } ,
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
2023-06-07 09:46:18 +00:00
assert response [ " endpointConfiguration " ] == { " types " : [ " PRIVATE " ] }
2020-02-03 16:21:22 +00:00
# 2. test creating rest api with REGIONAL endpointConfiguration
response = client . create_rest_api (
name = " my_api2 " ,
description = " this is my api " ,
endpointConfiguration = { " types " : [ " REGIONAL " ] } ,
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
2023-06-07 09:46:18 +00:00
assert response [ " endpointConfiguration " ] == { " types " : [ " REGIONAL " ] }
2020-02-03 16:21:22 +00:00
# 3. test creating rest api with EDGE endpointConfiguration
response = client . create_rest_api (
name = " my_api3 " ,
description = " this is my api " ,
endpointConfiguration = { " types " : [ " EDGE " ] } ,
)
api_id = response [ " id " ]
response = client . get_rest_api ( restApiId = api_id )
2023-06-07 09:46:18 +00:00
assert response [ " endpointConfiguration " ] == { " types " : [ " EDGE " ] }
2020-02-03 16:21:22 +00:00
2019-11-04 09:12:24 +00:00
@mock_apigateway
def test_create_resource__validate_name ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2020-01-29 19:28:37 +00:00
invalid_names = [ " /users " , " users/ " , " users/ {user_id} " , " us { er " , " us+er " ]
2023-04-01 22:37:57 +00:00
valid_names = [ " users " , " {user_id} " , " { proxy+} " , " { pro:xy+} " , " us:er_0-9 " ]
2019-11-04 09:12:24 +00:00
# All invalid names should throw an exception
for name in invalid_names :
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . create_resource ( restApiId = api_id , parentId = root_id , pathPart = name )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Code " ] == " BadRequestException "
assert (
err [ " Message " ]
== " Resource ' s path part only allow a-zA-Z0-9._- and curly braces at the beginning and the end and an optional plus sign before the closing brace. "
2019-11-04 09:12:24 +00:00
)
# All valid names should go through
for name in valid_names :
client . create_resource ( restApiId = api_id , parentId = root_id , pathPart = name )
2016-03-01 23:50:06 +00:00
@mock_apigateway
def test_create_resource ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2016-03-01 23:50:06 +00:00
resources = client . get_resources ( restApiId = api_id )
2019-10-31 15:44:26 +00:00
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2016-03-01 23:50:06 +00:00
2019-10-31 15:44:26 +00:00
root_resource = client . get_resource ( restApiId = api_id , resourceId = root_id )
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
root_resource [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
root_resource [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert root_resource == {
" path " : " / " ,
" id " : root_id ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2016-03-01 23:50:06 +00:00
2019-11-04 09:12:24 +00:00
client . create_resource ( restApiId = api_id , parentId = root_id , pathPart = " users " )
2016-03-01 23:50:06 +00:00
2019-10-31 15:44:26 +00:00
resources = client . get_resources ( restApiId = api_id ) [ " items " ]
2023-06-07 09:46:18 +00:00
assert len ( resources ) == 2
2019-10-31 15:44:26 +00:00
non_root_resource = [ resource for resource in resources if resource [ " path " ] != " / " ] [
0
]
2016-03-01 23:50:06 +00:00
2019-11-04 09:12:24 +00:00
client . delete_resource ( restApiId = api_id , resourceId = non_root_resource [ " id " ] )
2016-03-01 23:50:06 +00:00
2023-06-07 09:46:18 +00:00
assert len ( client . get_resources ( restApiId = api_id ) [ " items " ] ) == 1
2016-03-01 23:50:06 +00:00
2016-03-05 15:54:19 +00:00
@mock_apigateway
def test_child_resource ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2016-03-05 15:54:19 +00:00
resources = client . get_resources ( restApiId = api_id )
2019-10-31 15:44:26 +00:00
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2016-03-05 15:54:19 +00:00
response = client . create_resource (
2019-10-31 15:44:26 +00:00
restApiId = api_id , parentId = root_id , pathPart = " users "
2016-03-05 15:54:19 +00:00
)
2019-10-31 15:44:26 +00:00
users_id = response [ " id " ]
2016-03-05 15:54:19 +00:00
response = client . create_resource (
2019-10-31 15:44:26 +00:00
restApiId = api_id , parentId = users_id , pathPart = " tags "
2016-03-05 15:54:19 +00:00
)
2019-10-31 15:44:26 +00:00
tags_id = response [ " id " ]
2016-03-05 15:54:19 +00:00
2019-10-31 15:44:26 +00:00
child_resource = client . get_resource ( restApiId = api_id , resourceId = tags_id )
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
child_resource [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
child_resource [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert child_resource == {
" path " : " /users/tags " ,
" pathPart " : " tags " ,
" parentId " : users_id ,
" id " : tags_id ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2016-03-05 15:54:19 +00:00
2016-03-01 23:50:06 +00:00
@mock_apigateway
def test_create_method ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2016-03-01 23:50:06 +00:00
resources = client . get_resources ( restApiId = api_id )
2019-10-31 15:44:26 +00:00
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2016-03-01 23:50:06 +00:00
client . put_method (
2022-08-28 13:10:31 +00:00
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
authorizationType = " none " ,
requestParameters = { " method.request.header.InvocationType " : True } ,
2016-03-01 23:50:06 +00:00
)
2019-10-31 15:44:26 +00:00
response = client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
2016-03-01 23:50:06 +00:00
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" httpMethod " : " GET " ,
" authorizationType " : " none " ,
" apiKeyRequired " : False ,
" methodResponses " : { } ,
" requestParameters " : { " method.request.header.InvocationType " : True } ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2020-02-14 18:26:27 +00:00
@mock_apigateway
def test_create_method_apikeyrequired ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
client . put_method (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
authorizationType = " none " ,
apiKeyRequired = True ,
)
response = client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" httpMethod " : " GET " ,
" authorizationType " : " none " ,
" apiKeyRequired " : True ,
" methodResponses " : { } ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2016-03-01 23:50:06 +00:00
@mock_apigateway
def test_create_method_response ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2016-03-01 23:50:06 +00:00
resources = client . get_resources ( restApiId = api_id )
2019-10-31 15:44:26 +00:00
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2016-03-01 23:50:06 +00:00
client . put_method (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " none "
2016-03-01 23:50:06 +00:00
)
2019-10-31 15:44:26 +00:00
response = client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
2016-03-01 23:50:06 +00:00
response = client . put_method_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-01 23:50:06 +00:00
)
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" ResponseMetadata " : { " HTTPStatusCode " : 201 } ,
" statusCode " : " 200 " ,
}
2016-03-01 23:50:06 +00:00
response = client . get_method_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-01 23:50:06 +00:00
)
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
" statusCode " : " 200 " ,
}
2016-03-01 23:50:06 +00:00
response = client . delete_method_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-01 23:50:06 +00:00
)
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == { " ResponseMetadata " : { " HTTPStatusCode " : 204 } }
2016-03-02 20:18:11 +00:00
2022-05-16 15:13:23 +00:00
@mock_apigateway
def test_get_method_unknown_resource_id ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
with pytest . raises ( ClientError ) as ex :
client . get_method ( restApiId = api_id , resourceId = " sth " , httpMethod = " GET " )
err = ex . value . response [ " Error " ]
2023-06-07 09:46:18 +00:00
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid resource identifier specified "
2022-05-16 15:13:23 +00:00
2021-09-21 15:20:46 +00:00
@mock_apigateway
def test_delete_method ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
client . put_method (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " none "
)
client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
client . delete_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
with pytest . raises ( ClientError ) as ex :
client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
err = ex . value . response [ " Error " ]
2023-06-07 09:46:18 +00:00
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid Method identifier specified "
2021-09-21 15:20:46 +00:00
2016-03-02 20:18:11 +00:00
@mock_apigateway
def test_integrations ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2016-03-02 20:18:11 +00:00
resources = client . get_resources ( restApiId = api_id )
2019-10-31 15:44:26 +00:00
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2016-03-02 20:18:11 +00:00
client . put_method (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " none "
2016-03-02 20:18:11 +00:00
)
client . put_method_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-02 20:18:11 +00:00
)
response = client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
2019-10-31 15:44:26 +00:00
httpMethod = " GET " ,
type = " HTTP " ,
2022-05-19 10:16:33 +00:00
passthroughBehavior = " WHEN_NO_TEMPLATES " ,
2019-10-31 15:44:26 +00:00
uri = " http://httpbin.org/robots.txt " ,
2019-11-04 09:12:24 +00:00
integrationHttpMethod = " POST " ,
2022-06-14 10:07:30 +00:00
requestParameters = { " integration.request.header.X-Custom " : " ' Custom ' " } ,
2022-11-21 21:46:07 +00:00
contentHandling = " CONVERT_TO_TEXT " ,
credentials = f " arn:aws:iam:: { DEFAULT_ACCOUNT_ID } :role/apigateway-invoke-lambda-exec-role " ,
tlsConfig = { " insecureSkipVerification " : True } ,
2023-01-23 10:48:59 +00:00
connectionType = " INTERNET " ,
2016-03-02 20:18:11 +00:00
)
2022-11-21 21:46:07 +00:00
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" ResponseMetadata " : { " HTTPStatusCode " : 201 } ,
" httpMethod " : " POST " ,
" type " : " HTTP " ,
" uri " : " http://httpbin.org/robots.txt " ,
" passthroughBehavior " : " WHEN_NO_TEMPLATES " ,
" cacheKeyParameters " : [ ] ,
" requestParameters " : { " integration.request.header.X-Custom " : " ' Custom ' " } ,
" contentHandling " : " CONVERT_TO_TEXT " ,
" credentials " : f " arn:aws:iam:: { DEFAULT_ACCOUNT_ID } :role/apigateway-invoke-lambda-exec-role " ,
" tlsConfig " : { " insecureSkipVerification " : True } ,
" connectionType " : " INTERNET " ,
}
2016-03-04 23:02:07 +00:00
response = client . get_integration (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET "
2016-03-04 23:02:07 +00:00
)
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
" httpMethod " : " POST " ,
" type " : " HTTP " ,
" uri " : " http://httpbin.org/robots.txt " ,
" passthroughBehavior " : " WHEN_NO_TEMPLATES " ,
" cacheKeyParameters " : [ ] ,
" requestParameters " : { " integration.request.header.X-Custom " : " ' Custom ' " } ,
" contentHandling " : " CONVERT_TO_TEXT " ,
" credentials " : f " arn:aws:iam:: { DEFAULT_ACCOUNT_ID } :role/apigateway-invoke-lambda-exec-role " ,
" tlsConfig " : { " insecureSkipVerification " : True } ,
" connectionType " : " INTERNET " ,
}
2016-03-04 23:02:07 +00:00
2019-10-31 15:44:26 +00:00
response = client . get_resource ( restApiId = api_id , resourceId = root_id )
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response [ " resourceMethods " ] [ " GET " ] [ " httpMethod " ] == " GET "
assert response [ " resourceMethods " ] [ " GET " ] [ " authorizationType " ] == " none "
assert response [ " resourceMethods " ] [ " GET " ] [ " methodIntegration " ] == {
" httpMethod " : " POST " ,
" type " : " HTTP " ,
" uri " : " http://httpbin.org/robots.txt " ,
" cacheKeyParameters " : [ ] ,
" passthroughBehavior " : " WHEN_NO_TEMPLATES " ,
" requestParameters " : { " integration.request.header.X-Custom " : " ' Custom ' " } ,
" contentHandling " : " CONVERT_TO_TEXT " ,
" credentials " : f " arn:aws:iam:: { DEFAULT_ACCOUNT_ID } :role/apigateway-invoke-lambda-exec-role " ,
" tlsConfig " : { " insecureSkipVerification " : True } ,
" connectionType " : " INTERNET " ,
}
2016-03-04 23:02:07 +00:00
2019-10-31 15:44:26 +00:00
client . delete_integration ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
response = client . get_resource ( restApiId = api_id , resourceId = root_id )
2023-06-07 09:46:18 +00:00
assert " methodIntegration " not in response [ " resourceMethods " ] [ " GET " ]
2016-03-04 23:35:03 +00:00
2016-08-10 03:55:59 +00:00
# Create a new integration with a requestTemplates config
client . put_method (
restApiId = api_id ,
resourceId = root_id ,
2019-10-31 15:44:26 +00:00
httpMethod = " POST " ,
authorizationType = " none " ,
2016-08-10 03:55:59 +00:00
)
templates = {
2017-02-24 02:37:43 +00:00
# example based on
# http://docs.aws.amazon.com/apigateway/latest/developerguide/api-as-kinesis-proxy-export-swagger-with-extensions.html
2019-10-31 15:44:26 +00:00
" application/json " : ' { \n " StreamName " : " $input.params( \' stream-name \' ) " , \n " Records " : [] \n } '
2016-08-10 03:55:59 +00:00
}
2019-10-31 15:44:26 +00:00
test_uri = " http://example.com/foobar.txt "
2023-06-07 09:46:18 +00:00
client . put_integration (
2016-08-10 03:55:59 +00:00
restApiId = api_id ,
resourceId = root_id ,
2019-10-31 15:44:26 +00:00
httpMethod = " POST " ,
type = " HTTP " ,
2016-08-10 03:55:59 +00:00
uri = test_uri ,
2019-10-31 15:44:26 +00:00
requestTemplates = templates ,
2022-05-19 10:16:33 +00:00
passthroughBehavior = " WHEN_NO_MATCH " ,
2019-11-04 09:12:24 +00:00
integrationHttpMethod = " POST " ,
2022-02-18 23:31:33 +00:00
timeoutInMillis = 29000 ,
2016-08-10 03:55:59 +00:00
)
response = client . get_integration (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " POST "
2016-08-10 03:55:59 +00:00
)
2023-06-07 09:46:18 +00:00
assert response [ " uri " ] == test_uri
assert response [ " requestTemplates " ] == templates
assert response [ " passthroughBehavior " ] == " WHEN_NO_MATCH "
assert response [ " timeoutInMillis " ] == 29000
2016-08-10 03:55:59 +00:00
2016-03-04 23:35:03 +00:00
2016-03-05 14:48:37 +00:00
@mock_apigateway
def test_integration_response ( ) :
2019-10-31 15:44:26 +00:00
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2016-03-05 14:48:37 +00:00
resources = client . get_resources ( restApiId = api_id )
2019-10-31 15:44:26 +00:00
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
2016-03-05 14:48:37 +00:00
client . put_method (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " none "
2016-03-05 14:48:37 +00:00
)
client . put_method_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-05 14:48:37 +00:00
)
2019-11-04 09:12:24 +00:00
client . put_integration (
2016-03-05 14:48:37 +00:00
restApiId = api_id ,
resourceId = root_id ,
2019-10-31 15:44:26 +00:00
httpMethod = " GET " ,
type = " HTTP " ,
uri = " http://httpbin.org/robots.txt " ,
2019-11-04 09:12:24 +00:00
integrationHttpMethod = " POST " ,
2016-03-05 14:48:37 +00:00
)
response = client . put_integration_response (
restApiId = api_id ,
resourceId = root_id ,
2019-10-31 15:44:26 +00:00
httpMethod = " GET " ,
statusCode = " 200 " ,
selectionPattern = " foobar " ,
2022-11-16 23:46:50 +00:00
responseParameters = {
" method.response.header.Location " : " integration.response.body.redirect.url " ,
" method.response.header.x-user-id " : " integration.response.header.x-userid " ,
} ,
2019-11-04 09:12:24 +00:00
responseTemplates = { } ,
2016-03-05 14:48:37 +00:00
)
2020-06-10 06:58:40 +00:00
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" statusCode " : " 200 " ,
" selectionPattern " : " foobar " ,
" ResponseMetadata " : { " HTTPStatusCode " : 201 } ,
" responseTemplates " : { } , # Note: TF compatibility
" responseParameters " : {
" method.response.header.Location " : " integration.response.body.redirect.url " ,
" method.response.header.x-user-id " : " integration.response.header.x-userid " ,
} ,
}
2016-03-05 14:48:37 +00:00
response = client . get_integration_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-05 14:48:37 +00:00
)
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" statusCode " : " 200 " ,
" selectionPattern " : " foobar " ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
" responseTemplates " : { } , # Note: TF compatibility
" responseParameters " : {
" method.response.header.Location " : " integration.response.body.redirect.url " ,
" method.response.header.x-user-id " : " integration.response.header.x-userid " ,
} ,
}
2019-10-31 15:44:26 +00:00
response = client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
2017-02-24 02:37:43 +00:00
# this is hard to match against, so remove it
2019-10-31 15:44:26 +00:00
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response [ " methodIntegration " ] [ " integrationResponses " ] == {
" 200 " : {
" responseTemplates " : { } , # Note: TF compatibility
" selectionPattern " : " foobar " ,
" statusCode " : " 200 " ,
" responseParameters " : {
" method.response.header.Location " : " integration.response.body.redirect.url " ,
" method.response.header.x-user-id " : " integration.response.header.x-userid " ,
} ,
2016-03-05 14:48:37 +00:00
}
2023-06-07 09:46:18 +00:00
}
2016-03-05 14:48:37 +00:00
2023-06-07 09:46:18 +00:00
client . delete_integration_response (
2019-10-31 15:44:26 +00:00
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
2016-03-05 14:48:37 +00:00
)
2019-10-31 15:44:26 +00:00
response = client . get_method ( restApiId = api_id , resourceId = root_id , httpMethod = " GET " )
2023-06-07 09:46:18 +00:00
assert response [ " methodIntegration " ] [ " integrationResponses " ] == { }
2016-03-05 14:48:37 +00:00
2020-06-10 06:58:40 +00:00
# adding a new method and perfomring put intergration with contentHandling as CONVERT_TO_BINARY
client . put_method (
restApiId = api_id , resourceId = root_id , httpMethod = " PUT " , authorizationType = " none "
)
client . put_method_response (
restApiId = api_id , resourceId = root_id , httpMethod = " PUT " , statusCode = " 200 "
)
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " PUT " ,
type = " HTTP " ,
uri = " http://httpbin.org/robots.txt " ,
integrationHttpMethod = " POST " ,
)
response = client . put_integration_response (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " PUT " ,
statusCode = " 200 " ,
selectionPattern = " foobar " ,
responseTemplates = { } ,
contentHandling = " CONVERT_TO_BINARY " ,
)
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" statusCode " : " 200 " ,
" selectionPattern " : " foobar " ,
" ResponseMetadata " : { " HTTPStatusCode " : 201 } ,
" responseTemplates " : { } , # Note: TF compatibility
" contentHandling " : " CONVERT_TO_BINARY " ,
}
2020-06-10 06:58:40 +00:00
response = client . get_integration_response (
restApiId = api_id , resourceId = root_id , httpMethod = " PUT " , statusCode = " 200 "
)
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" statusCode " : " 200 " ,
" selectionPattern " : " foobar " ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
" responseTemplates " : { } , # Note: TF compatibility
" contentHandling " : " CONVERT_TO_BINARY " ,
}
2020-06-10 06:58:40 +00:00
2016-03-05 14:48:37 +00:00
2020-02-18 16:49:35 +00:00
@mock_apigateway
@mock_cognitoidp
def test_update_authorizer_configuration ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
authorizer_name = " my_authorizer "
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
cognito_client = boto3 . client ( " cognito-idp " , region_name = " us-west-2 " )
user_pool_arn = cognito_client . create_user_pool ( PoolName = " my_cognito_pool " ) [
" UserPool "
] [ " Arn " ]
response = client . create_authorizer (
restApiId = api_id ,
name = authorizer_name ,
type = " COGNITO_USER_POOLS " ,
providerARNs = [ user_pool_arn ] ,
identitySource = " method.request.header.Authorization " ,
)
authorizer_id = response [ " id " ]
response = client . get_authorizer ( restApiId = api_id , authorizerId = authorizer_id )
# createdDate is hard to match against, remove it
response . pop ( " createdDate " , None )
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" id " : authorizer_id ,
" name " : authorizer_name ,
" type " : " COGNITO_USER_POOLS " ,
" providerARNs " : [ user_pool_arn ] ,
" identitySource " : " method.request.header.Authorization " ,
" authorizerResultTtlInSeconds " : 300 ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2020-02-18 16:49:35 +00:00
client . update_authorizer (
restApiId = api_id ,
authorizerId = authorizer_id ,
patchOperations = [ { " op " : " replace " , " path " : " /type " , " value " : " TOKEN " } ] ,
)
authorizer = client . get_authorizer ( restApiId = api_id , authorizerId = authorizer_id )
2023-06-07 09:46:18 +00:00
assert authorizer [ " type " ] == " TOKEN "
2020-02-18 16:49:35 +00:00
client . update_authorizer (
restApiId = api_id ,
authorizerId = authorizer_id ,
patchOperations = [ { " op " : " replace " , " path " : " /type " , " value " : " REQUEST " } ] ,
)
authorizer = client . get_authorizer ( restApiId = api_id , authorizerId = authorizer_id )
2023-06-07 09:46:18 +00:00
assert authorizer [ " type " ] == " REQUEST "
2020-02-18 16:49:35 +00:00
# TODO: implement mult-update tests
2023-06-07 09:46:18 +00:00
with pytest . raises ( Exception ) as exc :
2020-02-18 16:49:35 +00:00
client . update_authorizer (
restApiId = api_id ,
authorizerId = authorizer_id ,
patchOperations = [
{ " op " : " add " , " path " : " /notasetting " , " value " : " eu-west-1 " }
] ,
)
2023-06-07 09:46:18 +00:00
if not settings . TEST_SERVER_MODE :
assert ' Patch operation " add " not implemented ' in str ( exc . value )
2020-02-18 16:49:35 +00:00
@mock_apigateway
def test_non_existent_authorizer ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
2022-10-11 13:16:27 +00:00
with pytest . raises ( ClientError ) as exc :
client . get_authorizer ( restApiId = api_id , authorizerId = " xxx " )
err = exc . value . response [ " Error " ]
2023-06-07 09:46:18 +00:00
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid Authorizer identifier specified "
2022-10-11 13:16:27 +00:00
with pytest . raises ( ClientError ) as exc :
client . update_authorizer (
restApiId = api_id ,
authorizerId = " xxx " ,
patchOperations = [ { " op " : " add " , " path " : " /type " , " value " : " sth " } ] ,
)
err = exc . value . response [ " Error " ]
2023-06-07 09:46:18 +00:00
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid Authorizer identifier specified "
2020-02-18 16:49:35 +00:00
@mock_apigateway
@mock_cognitoidp
def test_create_authorizer ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
authorizer_name = " my_authorizer "
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
cognito_client = boto3 . client ( " cognito-idp " , region_name = " us-west-2 " )
user_pool_arn = cognito_client . create_user_pool ( PoolName = " my_cognito_pool " ) [
" UserPool "
] [ " Arn " ]
response = client . create_authorizer (
restApiId = api_id ,
name = authorizer_name ,
type = " COGNITO_USER_POOLS " ,
providerARNs = [ user_pool_arn ] ,
identitySource = " method.request.header.Authorization " ,
)
authorizer_id = response [ " id " ]
response = client . get_authorizer ( restApiId = api_id , authorizerId = authorizer_id )
# createdDate is hard to match against, remove it
response . pop ( " createdDate " , None )
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" id " : authorizer_id ,
" name " : authorizer_name ,
" type " : " COGNITO_USER_POOLS " ,
" providerARNs " : [ user_pool_arn ] ,
" identitySource " : " method.request.header.Authorization " ,
" authorizerResultTtlInSeconds " : 300 ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2020-02-18 16:49:35 +00:00
authorizer_name2 = " my_authorizer2 "
response = client . create_authorizer (
restApiId = api_id ,
name = authorizer_name2 ,
type = " COGNITO_USER_POOLS " ,
providerARNs = [ user_pool_arn ] ,
identitySource = " method.request.header.Authorization " ,
)
authorizer_id2 = response [ " id " ]
response = client . get_authorizers ( restApiId = api_id )
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response [ " items " ] [ 0 ] [ " id " ] in [ authorizer_id , authorizer_id2 ]
assert response [ " items " ] [ 1 ] [ " id " ] in [ authorizer_id , authorizer_id2 ]
2020-02-18 16:49:35 +00:00
new_authorizer_name_with_vars = " authorizer_with_vars "
response = client . create_authorizer (
restApiId = api_id ,
name = new_authorizer_name_with_vars ,
type = " COGNITO_USER_POOLS " ,
providerARNs = [ user_pool_arn ] ,
identitySource = " method.request.header.Authorization " ,
)
authorizer_id3 = response [ " id " ]
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" name " : new_authorizer_name_with_vars ,
" id " : authorizer_id3 ,
" type " : " COGNITO_USER_POOLS " ,
" providerARNs " : [ user_pool_arn ] ,
" identitySource " : " method.request.header.Authorization " ,
" authorizerResultTtlInSeconds " : 300 ,
" ResponseMetadata " : { " HTTPStatusCode " : 201 } ,
}
2020-02-18 16:49:35 +00:00
stage = client . get_authorizer ( restApiId = api_id , authorizerId = authorizer_id3 )
2023-06-07 09:46:18 +00:00
assert stage [ " name " ] == new_authorizer_name_with_vars
assert stage [ " id " ] == authorizer_id3
assert stage [ " type " ] == " COGNITO_USER_POOLS "
assert stage [ " providerARNs " ] == [ user_pool_arn ]
assert stage [ " identitySource " ] == " method.request.header.Authorization "
assert stage [ " authorizerResultTtlInSeconds " ] == 300
2020-02-18 16:49:35 +00:00
@mock_apigateway
@mock_cognitoidp
def test_delete_authorizer ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
authorizer_name = " my_authorizer "
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
cognito_client = boto3 . client ( " cognito-idp " , region_name = " us-west-2 " )
user_pool_arn = cognito_client . create_user_pool ( PoolName = " my_cognito_pool " ) [
" UserPool "
] [ " Arn " ]
response = client . create_authorizer (
restApiId = api_id ,
name = authorizer_name ,
type = " COGNITO_USER_POOLS " ,
providerARNs = [ user_pool_arn ] ,
identitySource = " method.request.header.Authorization " ,
)
authorizer_id = response [ " id " ]
response = client . get_authorizer ( restApiId = api_id , authorizerId = authorizer_id )
# createdDate is hard to match against, remove it
response . pop ( " createdDate " , None )
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" id " : authorizer_id ,
" name " : authorizer_name ,
" type " : " COGNITO_USER_POOLS " ,
" providerARNs " : [ user_pool_arn ] ,
" identitySource " : " method.request.header.Authorization " ,
" authorizerResultTtlInSeconds " : 300 ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
}
2020-02-18 16:49:35 +00:00
authorizer_name2 = " my_authorizer2 "
response = client . create_authorizer (
restApiId = api_id ,
name = authorizer_name2 ,
type = " COGNITO_USER_POOLS " ,
providerARNs = [ user_pool_arn ] ,
identitySource = " method.request.header.Authorization " ,
)
authorizer_id2 = response [ " id " ]
authorizers = client . get_authorizers ( restApiId = api_id ) [ " items " ]
2023-06-07 09:46:18 +00:00
assert sorted ( [ authorizer [ " name " ] for authorizer in authorizers ] ) == sorted (
[ authorizer_name2 , authorizer_name ]
2020-02-18 16:49:35 +00:00
)
# delete stage
response = client . delete_authorizer ( restApiId = api_id , authorizerId = authorizer_id2 )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 202
2020-02-18 16:49:35 +00:00
# verify other stage still exists
authorizers = client . get_authorizers ( restApiId = api_id ) [ " items " ]
2023-06-07 09:46:18 +00:00
assert [ authorizer [ " name " ] for authorizer in authorizers ] == [ authorizer_name ]
2020-02-18 16:49:35 +00:00
2020-05-03 03:01:46 +00:00
@mock_apigateway
def test_put_integration_response_with_response_template ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
client . put_method (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " NONE "
)
client . put_method_response (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
)
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
type = " HTTP " ,
uri = " http://httpbin.org/robots.txt " ,
integrationHttpMethod = " POST " ,
)
client . put_integration_response (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
statusCode = " 200 " ,
2020-05-04 08:27:57 +00:00
selectionPattern = " foobar " ,
2022-11-16 23:46:50 +00:00
responseParameters = {
" method.response.header.Location " : " integration.response.body.redirect.url " ,
" method.response.header.x-user-id " : " integration.response.header.x-userid " ,
} ,
2020-05-04 08:27:57 +00:00
responseTemplates = { " application/json " : json . dumps ( { " data " : " test " } ) } ,
)
2020-05-03 03:01:46 +00:00
response = client . get_integration_response (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
)
# this is hard to match against, so remove it
response [ " ResponseMetadata " ] . pop ( " HTTPHeaders " , None )
response [ " ResponseMetadata " ] . pop ( " RetryAttempts " , None )
2023-06-07 09:46:18 +00:00
assert response == {
" statusCode " : " 200 " ,
" selectionPattern " : " foobar " ,
" ResponseMetadata " : { " HTTPStatusCode " : 200 } ,
" responseTemplates " : { " application/json " : json . dumps ( { " data " : " test " } ) } ,
" responseParameters " : {
" method.response.header.Location " : " integration.response.body.redirect.url " ,
" method.response.header.x-user-id " : " integration.response.header.x-userid " ,
} ,
}
2019-11-04 09:12:24 +00:00
2020-05-04 08:27:57 +00:00
2022-08-24 15:38:05 +00:00
@mock_apigateway
def test_put_integration_response_but_integration_not_found ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
client . put_method (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " NONE "
)
client . put_method_response (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
)
with pytest . raises ( ClientError ) as ex :
client . put_integration_response (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
statusCode = " 200 " ,
selectionPattern = " foobar " ,
responseTemplates = { " application/json " : json . dumps ( { " data " : " test " } ) } ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2022-08-24 15:38:05 +00:00
2019-11-04 09:12:24 +00:00
@mock_apigateway
def test_put_integration_validation ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
client . put_method (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , authorizationType = " NONE "
)
client . put_method_response (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
)
http_types = [ " HTTP " , " HTTP_PROXY " ]
aws_types = [ " AWS " , " AWS_PROXY " ]
types_requiring_integration_method = http_types + aws_types
types_not_requiring_integration_method = [ " MOCK " ]
2021-10-18 19:44:29 +00:00
for _type in types_requiring_integration_method :
2019-11-04 09:12:24 +00:00
# Ensure that integrations of these types fail if no integrationHttpMethod is provided
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " http://httpbin.org/robots.txt " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Enumeration value for HttpMethod must be non-empty "
2019-11-04 09:12:24 +00:00
)
2021-10-18 19:44:29 +00:00
for _type in types_not_requiring_integration_method :
2019-11-04 09:12:24 +00:00
# Ensure that integrations of these types do not need the integrationHttpMethod
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " http://httpbin.org/robots.txt " ,
)
2021-10-18 19:44:29 +00:00
for _type in http_types :
2019-11-04 09:12:24 +00:00
# Ensure that it works fine when providing the integrationHttpMethod-argument
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " http://httpbin.org/robots.txt " ,
integrationHttpMethod = " POST " ,
)
2021-10-18 19:44:29 +00:00
for _type in [ " AWS " ] :
2019-11-04 09:12:24 +00:00
# Ensure that it works fine when providing the integrationHttpMethod + credentials
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
2022-11-17 22:41:08 +00:00
credentials = f " arn:aws:iam:: { ACCOUNT_ID } :role/service-role/testfunction-role-oe783psq " ,
2019-11-04 09:12:24 +00:00
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " arn:aws:apigateway:us-west-2:s3:path/b/k " ,
integrationHttpMethod = " POST " ,
)
2021-10-18 19:44:29 +00:00
for _type in aws_types :
2019-11-04 09:12:24 +00:00
# Ensure that credentials are not required when URI points to a Lambda stream
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " arn:aws:apigateway:eu-west-1:lambda:path/2015-03-31/functions/arn:aws:lambda:eu-west-1:012345678901:function:MyLambda/invocations " ,
integrationHttpMethod = " POST " ,
)
2021-10-18 19:44:29 +00:00
for _type in [ " AWS_PROXY " ] :
2019-11-04 09:12:24 +00:00
# Ensure that aws_proxy does not support S3
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
2022-11-17 22:41:08 +00:00
credentials = f " arn:aws:iam:: { ACCOUNT_ID } :role/service-role/testfunction-role-oe783psq " ,
2019-11-04 09:12:24 +00:00
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " arn:aws:apigateway:us-west-2:s3:path/b/k " ,
integrationHttpMethod = " POST " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Integrations of type ' AWS_PROXY ' currently only supports Lambda function and Firehose stream invocations. "
2019-11-04 09:12:24 +00:00
)
2021-10-18 19:44:29 +00:00
for _type in aws_types :
2019-11-04 09:12:24 +00:00
# Ensure that the Role ARN is for the current account
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
credentials = " arn:aws:iam::000000000000:role/service-role/testrole " ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " arn:aws:apigateway:us-west-2:s3:path/b/k " ,
integrationHttpMethod = " POST " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " AccessDeniedException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Cross-account pass role is not allowed. "
2019-11-04 09:12:24 +00:00
)
2021-10-18 19:44:29 +00:00
for _type in [ " AWS " ] :
2019-11-04 09:12:24 +00:00
# Ensure that the Role ARN is specified for aws integrations
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " arn:aws:apigateway:us-west-2:s3:path/b/k " ,
integrationHttpMethod = " POST " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Role ARN must be specified for AWS integrations "
2019-11-04 09:12:24 +00:00
)
2021-10-18 19:44:29 +00:00
for _type in http_types :
2019-11-04 09:12:24 +00:00
# Ensure that the URI is valid HTTP
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " non-valid-http " ,
integrationHttpMethod = " POST " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid HTTP endpoint specified for URI "
2019-11-04 09:12:24 +00:00
)
2021-10-18 19:44:29 +00:00
for _type in aws_types :
2019-11-04 09:12:24 +00:00
# Ensure that the URI is an ARN
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " non-valid-arn " ,
integrationHttpMethod = " POST " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid ARN specified in the request "
2019-11-04 09:12:24 +00:00
)
2021-10-18 19:44:29 +00:00
for _type in aws_types :
2019-11-04 09:12:24 +00:00
# Ensure that the URI is a valid ARN
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2019-11-04 09:12:24 +00:00
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = " GET " ,
2021-10-18 19:44:29 +00:00
type = _type ,
2019-11-04 09:12:24 +00:00
uri = " arn:aws:iam::0000000000:role/service-role/asdf " ,
integrationHttpMethod = " POST " ,
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " AWS ARN for integration must contain path or action "
2019-11-04 09:12:24 +00:00
)
2020-04-07 21:48:42 +00:00
@mock_apigateway
def test_create_domain_names ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
test_certificate_private_key = " testPrivateKey "
2020-04-08 16:24:26 +00:00
# success case with valid params
2020-04-08 10:06:30 +00:00
response = client . create_domain_name (
domainName = domain_name ,
certificateName = test_certificate_name ,
certificatePrivateKey = test_certificate_private_key ,
)
2023-06-07 09:46:18 +00:00
assert response [ " domainName " ] == domain_name
assert response [ " certificateName " ] == test_certificate_name
2020-04-08 16:24:26 +00:00
# without domain name it should throw BadRequestException
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-08 16:24:26 +00:00
client . create_domain_name ( domainName = " " )
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Message " ] == " No Domain Name specified "
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
2020-04-08 16:24:26 +00:00
@mock_apigateway
def test_get_domain_names ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
# without any domain names already present
result = client . get_domain_names ( )
2023-06-07 09:46:18 +00:00
assert result [ " items " ] == [ ]
2020-04-08 16:24:26 +00:00
domain_name = " testDomain "
test_certificate_name = " test.certificate "
2020-04-09 07:12:44 +00:00
response = client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
2020-04-08 16:24:26 +00:00
2023-06-07 09:46:18 +00:00
assert response [ " domainName " ] == domain_name
assert response [ " certificateName " ] == test_certificate_name
assert response [ " domainNameStatus " ] == " AVAILABLE "
2020-04-08 16:24:26 +00:00
# after adding a new domain name
2020-04-07 21:48:42 +00:00
result = client . get_domain_names ( )
2023-06-07 09:46:18 +00:00
assert result [ " items " ] [ 0 ] [ " domainName " ] == domain_name
assert result [ " items " ] [ 0 ] [ " certificateName " ] == test_certificate_name
assert result [ " items " ] [ 0 ] [ " domainNameStatus " ] == " AVAILABLE "
2020-04-08 16:24:26 +00:00
@mock_apigateway
def test_get_domain_name ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
# adding a domain name
client . create_domain_name ( domainName = domain_name )
# retrieving the data of added domain name.
2020-04-07 21:48:42 +00:00
result = client . get_domain_name ( domainName = domain_name )
2023-06-07 09:46:18 +00:00
assert result [ " domainName " ] == domain_name
assert result [ " domainNameStatus " ] == " AVAILABLE "
2020-04-07 21:48:42 +00:00
2020-04-12 12:19:22 +00:00
@mock_apigateway
def test_create_model ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-04-14 07:06:00 +00:00
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
2020-04-12 12:19:22 +00:00
rest_api_id = response [ " id " ]
2020-04-14 07:06:00 +00:00
dummy_rest_api_id = " a12b3c4d "
2020-04-12 12:19:22 +00:00
model_name = " testModel "
description = " test model "
2020-04-14 07:06:00 +00:00
content_type = " application/json "
2020-04-12 12:19:22 +00:00
# success case with valid params
response = client . create_model (
restApiId = rest_api_id ,
name = model_name ,
description = description ,
2020-04-14 07:06:00 +00:00
contentType = content_type ,
2020-04-12 12:19:22 +00:00
)
2023-06-07 09:46:18 +00:00
assert response [ " name " ] == model_name
assert response [ " description " ] == description
2020-04-12 12:19:22 +00:00
# with an invalid rest_api_id it should throw NotFoundException
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-14 07:06:00 +00:00
client . create_model (
2020-04-12 12:19:22 +00:00
restApiId = dummy_rest_api_id ,
name = model_name ,
description = description ,
2020-04-14 07:06:00 +00:00
contentType = content_type ,
2020-04-12 12:19:22 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Message " ] == " Invalid Rest API Id specified "
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
2020-04-12 12:19:22 +00:00
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-14 07:06:00 +00:00
client . create_model (
2020-04-12 12:19:22 +00:00
restApiId = rest_api_id ,
name = " " ,
description = description ,
2020-04-14 07:06:00 +00:00
contentType = content_type ,
2020-04-12 12:19:22 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Message " ] == " No Model Name specified "
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
2020-04-12 12:19:22 +00:00
@mock_apigateway
def test_get_api_models ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-04-14 07:06:00 +00:00
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
2020-04-12 12:19:22 +00:00
rest_api_id = response [ " id " ]
model_name = " testModel "
description = " test model "
2020-04-14 07:06:00 +00:00
content_type = " application/json "
2020-04-12 12:19:22 +00:00
# when no models are present
2020-04-14 07:06:00 +00:00
result = client . get_models ( restApiId = rest_api_id )
2023-06-07 09:46:18 +00:00
assert result [ " items " ] == [ ]
2020-04-12 12:19:22 +00:00
# add a model
client . create_model (
restApiId = rest_api_id ,
name = model_name ,
description = description ,
2020-04-14 07:06:00 +00:00
contentType = content_type ,
2020-04-12 12:19:22 +00:00
)
# get models after adding
2020-04-14 07:06:00 +00:00
result = client . get_models ( restApiId = rest_api_id )
2020-04-12 12:19:22 +00:00
result [ " items " ] [ 0 ] [ " name " ] = model_name
result [ " items " ] [ 0 ] [ " description " ] = description
@mock_apigateway
def test_get_model_by_name ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-04-14 07:06:00 +00:00
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
2020-04-12 12:19:22 +00:00
rest_api_id = response [ " id " ]
2020-04-14 07:06:00 +00:00
dummy_rest_api_id = " a12b3c4d "
2020-04-12 12:19:22 +00:00
model_name = " testModel "
description = " test model "
2020-04-14 07:06:00 +00:00
content_type = " application/json "
2020-04-12 12:19:22 +00:00
# add a model
client . create_model (
restApiId = rest_api_id ,
name = model_name ,
description = description ,
2020-04-14 07:06:00 +00:00
contentType = content_type ,
2020-04-12 12:19:22 +00:00
)
# get models after adding
2020-04-14 07:06:00 +00:00
result = client . get_model ( restApiId = rest_api_id , modelName = model_name )
2020-04-12 12:19:22 +00:00
result [ " name " ] = model_name
result [ " description " ] = description
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-14 07:06:00 +00:00
client . get_model ( restApiId = dummy_rest_api_id , modelName = model_name )
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Message " ] == " Invalid Rest API Id specified "
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
2020-04-12 12:19:22 +00:00
@mock_apigateway
def test_get_model_with_invalid_name ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
2020-04-14 07:06:00 +00:00
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
2020-04-12 12:19:22 +00:00
rest_api_id = response [ " id " ]
# test with an invalid model name
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-14 07:06:00 +00:00
client . get_model ( restApiId = rest_api_id , modelName = " fake " )
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Message " ] == " Invalid Model Name specified "
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
2020-04-12 12:19:22 +00:00
2021-02-15 09:39:35 +00:00
@mock_apigateway
def test_api_key_value_min_length ( ) :
region_name = " us-east-1 "
client = boto3 . client ( " apigateway " , region_name = region_name )
apikey_value = " 12345 "
apikey_name = " TESTKEY1 "
payload = { " value " : apikey_value , " name " : apikey_name }
with pytest . raises ( ClientError ) as e :
client . create_api_key ( * * payload )
ex = e . value
2023-06-07 09:46:18 +00:00
assert ex . operation_name == " CreateApiKey "
assert ex . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 400
assert ex . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert (
ex . response [ " Error " ] [ " Message " ]
== " API Key value should be at least 20 characters "
2021-02-15 09:39:35 +00:00
)
@mock_apigateway
def test_get_api_key_include_value ( ) :
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
apikey_value = " 01234567890123456789 "
apikey_name = " TESTKEY1 "
payload = { " value " : apikey_value , " name " : apikey_name }
response = client . create_api_key ( * * payload )
api_key_id_one = response [ " id " ]
response = client . get_api_key ( apiKey = api_key_id_one , includeValue = True )
2023-06-07 09:46:18 +00:00
assert " value " in response
2021-02-15 09:39:35 +00:00
response = client . get_api_key ( apiKey = api_key_id_one )
2023-06-07 09:46:18 +00:00
assert " value " not in response
2021-02-15 09:39:35 +00:00
response = client . get_api_key ( apiKey = api_key_id_one , includeValue = True )
2023-06-07 09:46:18 +00:00
assert " value " in response
2021-02-15 09:39:35 +00:00
response = client . get_api_key ( apiKey = api_key_id_one , includeValue = False )
2023-06-07 09:46:18 +00:00
assert " value " not in response
2021-02-15 09:39:35 +00:00
response = client . get_api_key ( apiKey = api_key_id_one , includeValue = True )
2023-06-07 09:46:18 +00:00
assert " value " in response
2021-02-15 09:39:35 +00:00
@mock_apigateway
def test_get_api_keys_include_values ( ) :
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
apikey_value = " 01234567890123456789 "
apikey_name = " TESTKEY1 "
payload = { " value " : apikey_value , " name " : apikey_name }
apikey_value2 = " 01234567890123456789123 "
apikey_name2 = " TESTKEY1 "
payload2 = { " value " : apikey_value2 , " name " : apikey_name2 }
client . create_api_key ( * * payload )
client . create_api_key ( * * payload2 )
response = client . get_api_keys ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 2
2021-02-15 09:39:35 +00:00
for api_key in response [ " items " ] :
2023-06-07 09:46:18 +00:00
assert " value " not in api_key
2021-02-15 09:39:35 +00:00
response = client . get_api_keys ( includeValues = True )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 2
2021-02-15 09:39:35 +00:00
for api_key in response [ " items " ] :
2023-06-07 09:46:18 +00:00
assert " value " in api_key
2021-02-15 09:39:35 +00:00
response = client . get_api_keys ( includeValues = False )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 2
2021-02-15 09:39:35 +00:00
for api_key in response [ " items " ] :
2023-06-07 09:46:18 +00:00
assert " value " not in api_key
2021-02-15 09:39:35 +00:00
2019-11-27 14:49:37 +00:00
@mock_apigateway
def test_create_api_key ( ) :
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2021-02-15 09:39:35 +00:00
apikey_value = " 01234567890123456789 "
2019-11-27 14:49:37 +00:00
apikey_name = " TESTKEY1 "
payload = { " value " : apikey_value , " name " : apikey_name }
2020-07-15 06:00:44 +00:00
response = client . create_api_key ( * * payload )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 201
assert response [ " name " ] == apikey_name
assert response [ " value " ] == apikey_value
assert response [ " enabled " ] is False
assert response [ " stageKeys " ] == [ ]
2019-11-27 14:49:37 +00:00
response = client . get_api_keys ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 1
2019-11-27 14:49:37 +00:00
2020-09-01 07:25:59 +00:00
@mock_apigateway
2022-02-18 23:31:33 +00:00
def test_create_api_key_twice ( ) :
2020-09-01 07:25:59 +00:00
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2021-02-15 09:39:35 +00:00
apikey_value = " 01234567890123456789 "
2020-09-01 07:25:59 +00:00
apikey_name = " TESTKEY1 "
payload = { " value " : apikey_value , " name " : apikey_name }
client . create_api_key ( * * payload )
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-09-01 07:25:59 +00:00
client . create_api_key ( * * payload )
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " ConflictException "
2020-09-01 07:25:59 +00:00
2018-03-21 16:11:49 +00:00
@mock_apigateway
def test_api_keys ( ) :
2019-10-31 15:44:26 +00:00
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2018-03-21 16:11:49 +00:00
response = client . get_api_keys ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 0
2018-03-21 16:11:49 +00:00
2021-02-15 09:39:35 +00:00
apikey_value = " 01234567890123456789 "
2019-10-31 15:44:26 +00:00
apikey_name = " TESTKEY1 "
2019-11-27 15:12:30 +00:00
payload = {
" value " : apikey_value ,
" name " : apikey_name ,
" tags " : { " tag1 " : " test_tag1 " , " tag2 " : " 1 " } ,
}
2018-03-21 16:11:49 +00:00
response = client . create_api_key ( * * payload )
2019-11-27 14:49:37 +00:00
apikey_id = response [ " id " ]
2021-02-15 09:39:35 +00:00
apikey = client . get_api_key ( apiKey = response [ " id " ] , includeValue = True )
2023-06-07 09:46:18 +00:00
assert apikey [ " name " ] == apikey_name
assert apikey [ " value " ] == apikey_value
assert apikey [ " tags " ] [ " tag1 " ] == " test_tag1 "
assert apikey [ " tags " ] [ " tag2 " ] == " 1 "
2019-08-02 16:28:47 +00:00
patch_operations = [
2019-10-31 15:44:26 +00:00
{ " op " : " replace " , " path " : " /name " , " value " : " TESTKEY3_CHANGE " } ,
{ " op " : " replace " , " path " : " /customerId " , " value " : " 12345 " } ,
{ " op " : " replace " , " path " : " /description " , " value " : " APIKEY UPDATE TEST " } ,
{ " op " : " replace " , " path " : " /enabled " , " value " : " false " } ,
2019-08-02 16:28:47 +00:00
]
response = client . update_api_key ( apiKey = apikey_id , patchOperations = patch_operations )
2023-06-07 09:46:18 +00:00
assert response [ " name " ] == " TESTKEY3_CHANGE "
assert response [ " customerId " ] == " 12345 "
assert response [ " description " ] == " APIKEY UPDATE TEST "
assert response [ " enabled " ] is False
2019-08-02 16:28:47 +00:00
2019-11-27 14:49:37 +00:00
updated_api_key = client . get_api_key ( apiKey = apikey_id )
2023-06-07 09:46:18 +00:00
assert updated_api_key [ " name " ] == " TESTKEY3_CHANGE "
assert updated_api_key [ " customerId " ] == " 12345 "
assert updated_api_key [ " description " ] == " APIKEY UPDATE TEST "
assert updated_api_key [ " enabled " ] is False
2019-11-27 14:49:37 +00:00
2018-03-21 16:11:49 +00:00
response = client . get_api_keys ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 1
2018-03-21 16:11:49 +00:00
2019-11-27 14:49:37 +00:00
payload = { " name " : apikey_name }
client . create_api_key ( * * payload )
2018-03-21 16:11:49 +00:00
response = client . get_api_keys ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 2
2019-10-31 15:44:26 +00:00
2020-07-15 08:41:41 +00:00
response = client . delete_api_key ( apiKey = apikey_id )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 202
2019-11-27 14:49:37 +00:00
response = client . get_api_keys ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 1
2019-11-27 14:49:37 +00:00
2018-07-10 13:58:02 +00:00
@mock_apigateway
def test_usage_plans ( ) :
2019-10-31 15:44:26 +00:00
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2018-07-10 13:58:02 +00:00
response = client . get_usage_plans ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 0
2018-07-10 13:58:02 +00:00
2020-04-27 17:39:33 +00:00
# # Try to get info about a non existing usage
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-27 17:39:33 +00:00
client . get_usage_plan ( usagePlanId = " not_existing " )
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " Error " ] [ " Message " ] == " Invalid Usage Plan ID specified "
2020-04-27 17:39:33 +00:00
2019-10-31 15:44:26 +00:00
usage_plan_name = " TEST-PLAN "
payload = { " name " : usage_plan_name }
2018-07-10 13:58:02 +00:00
response = client . create_usage_plan ( * * payload )
2019-10-31 15:44:26 +00:00
usage_plan = client . get_usage_plan ( usagePlanId = response [ " id " ] )
2023-06-07 09:46:18 +00:00
assert usage_plan [ " name " ] == usage_plan_name
assert usage_plan [ " apiStages " ] == [ ]
2018-07-10 13:58:02 +00:00
2019-10-08 11:45:47 +00:00
payload = {
2019-10-31 15:44:26 +00:00
" name " : " TEST-PLAN-2 " ,
" description " : " Description " ,
" quota " : { " limit " : 10 , " period " : " DAY " , " offset " : 0 } ,
" throttle " : { " rateLimit " : 2 , " burstLimit " : 1 } ,
" apiStages " : [ { " apiId " : " foo " , " stage " : " bar " } ] ,
" tags " : { " tag_key " : " tag_value " } ,
2019-10-08 11:45:47 +00:00
}
2018-07-10 13:58:02 +00:00
response = client . create_usage_plan ( * * payload )
2019-10-31 15:44:26 +00:00
usage_plan_id = response [ " id " ]
2018-07-10 13:58:02 +00:00
usage_plan = client . get_usage_plan ( usagePlanId = usage_plan_id )
2019-10-08 11:45:47 +00:00
# The payload should remain unchanged
for key , value in payload . items ( ) :
2023-06-07 09:46:18 +00:00
assert usage_plan [ key ] == value
2019-10-08 11:45:47 +00:00
# Status code should be 200
2023-06-07 09:46:18 +00:00
assert usage_plan [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 200
2019-10-08 11:45:47 +00:00
# An Id should've been generated
2023-06-07 09:46:18 +00:00
assert usage_plan [ " id " ]
2018-07-10 13:58:02 +00:00
response = client . get_usage_plans ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 2
2018-07-10 13:58:02 +00:00
client . delete_usage_plan ( usagePlanId = usage_plan_id )
response = client . get_usage_plans ( )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 1
2019-10-31 15:44:26 +00:00
2018-07-11 16:17:58 +00:00
2021-02-25 07:46:11 +00:00
@mock_apigateway
def test_update_usage_plan ( ) :
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
payload = {
" name " : " TEST-PLAN-2 " ,
" description " : " Description " ,
" quota " : { " limit " : 10 , " period " : " DAY " , " offset " : 0 } ,
" throttle " : { " rateLimit " : 2 , " burstLimit " : 1 } ,
" apiStages " : [ { " apiId " : " foo " , " stage " : " bar " } ] ,
" tags " : { " tag_key " : " tag_value " } ,
}
response = client . create_usage_plan ( * * payload )
usage_plan_id = response [ " id " ]
response = client . update_usage_plan (
usagePlanId = usage_plan_id ,
patchOperations = [
{ " op " : " replace " , " path " : " /quota/limit " , " value " : " 1000 " } ,
{ " op " : " replace " , " path " : " /quota/period " , " value " : " MONTH " } ,
{ " op " : " replace " , " path " : " /throttle/rateLimit " , " value " : " 500 " } ,
{ " op " : " replace " , " path " : " /throttle/burstLimit " , " value " : " 1500 " } ,
2021-05-20 06:10:08 +00:00
{ " op " : " replace " , " path " : " /name " , " value " : " new-name " } ,
{ " op " : " replace " , " path " : " /description " , " value " : " new-description " } ,
{ " op " : " replace " , " path " : " /productCode " , " value " : " new-productionCode " } ,
2021-02-25 07:46:11 +00:00
] ,
)
2023-06-07 09:46:18 +00:00
assert response [ " quota " ] [ " limit " ] == 1000
assert response [ " quota " ] [ " period " ] == " MONTH "
assert response [ " name " ] == " new-name "
assert response [ " description " ] == " new-description "
assert response [ " productCode " ] == " new-productionCode "
2021-02-25 07:46:11 +00:00
2018-07-11 16:17:58 +00:00
@mock_apigateway
def test_usage_plan_keys ( ) :
2019-10-31 15:44:26 +00:00
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2018-07-11 16:17:58 +00:00
usage_plan_id = " test "
# Create an API key so we can use it
2019-10-31 15:44:26 +00:00
key_name = " test-api-key "
2018-07-11 16:17:58 +00:00
response = client . create_api_key ( name = key_name )
key_id = response [ " id " ]
key_value = response [ " value " ]
# Get current plan keys (expect none)
response = client . get_usage_plan_keys ( usagePlanId = usage_plan_id )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 0
2018-07-11 16:17:58 +00:00
# Create usage plan key
2019-10-31 15:44:26 +00:00
key_type = " API_KEY "
payload = { " usagePlanId " : usage_plan_id , " keyId " : key_id , " keyType " : key_type }
2018-07-11 16:17:58 +00:00
response = client . create_usage_plan_key ( * * payload )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 201
2018-07-11 16:17:58 +00:00
usage_plan_key_id = response [ " id " ]
# Get current plan keys (expect 1)
response = client . get_usage_plan_keys ( usagePlanId = usage_plan_id )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 1
2018-07-11 16:17:58 +00:00
# Get a single usage plan key and check it matches the created one
2019-10-31 15:44:26 +00:00
usage_plan_key = client . get_usage_plan_key (
usagePlanId = usage_plan_id , keyId = usage_plan_key_id
)
2023-06-07 09:46:18 +00:00
assert usage_plan_key [ " name " ] == key_name
assert usage_plan_key [ " id " ] == key_id
assert usage_plan_key [ " type " ] == key_type
assert usage_plan_key [ " value " ] == key_value
2018-07-11 16:17:58 +00:00
# Delete usage plan key
client . delete_usage_plan_key ( usagePlanId = usage_plan_id , keyId = key_id )
# Get current plan keys (expect none)
response = client . get_usage_plan_keys ( usagePlanId = usage_plan_id )
2023-06-07 09:46:18 +00:00
assert len ( response [ " items " ] ) == 0
2019-10-31 15:44:26 +00:00
2020-04-27 17:39:33 +00:00
# Try to get info about a non existing api key
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-27 17:39:33 +00:00
client . get_usage_plan_key ( usagePlanId = usage_plan_id , keyId = " not_existing_key " )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid API Key identifier specified "
2020-04-27 17:39:33 +00:00
# Try to get info about an existing api key that has not jet added to a valid usage plan
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-27 17:39:33 +00:00
client . get_usage_plan_key ( usagePlanId = usage_plan_id , keyId = key_id )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid Usage Plan ID specified "
2020-04-27 17:39:33 +00:00
# Try to get info about an existing api key that has not jet added to a valid usage plan
2020-10-06 05:54:49 +00:00
with pytest . raises ( ClientError ) as ex :
2020-04-27 17:39:33 +00:00
client . get_usage_plan_key ( usagePlanId = " not_existing_plan_id " , keyId = key_id )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid Usage Plan ID specified "
2020-04-27 17:39:33 +00:00
2018-07-11 16:17:58 +00:00
@mock_apigateway
def test_create_usage_plan_key_non_existent_api_key ( ) :
2019-10-31 15:44:26 +00:00
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2018-07-11 16:17:58 +00:00
usage_plan_id = " test "
# Attempt to create a usage plan key for a API key that doesn't exists
2023-06-07 09:46:18 +00:00
with pytest . raises ( ClientError ) as exc :
client . create_usage_plan_key (
usagePlanId = usage_plan_id , keyId = " non-existent " , keyType = " API_KEY "
)
err = exc . value . response [ " Error " ]
assert err [ " Code " ] == " NotFoundException "
assert err [ " Message " ] == " Invalid API Key identifier specified "
2018-10-17 12:44:00 +00:00
@mock_apigateway
def test_get_usage_plans_using_key_id ( ) :
2019-10-31 15:44:26 +00:00
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
2018-10-17 12:44:00 +00:00
# Create 2 Usage Plans
# one will be attached to an API Key, the other will remain unattached
2019-10-31 15:44:26 +00:00
attached_plan = client . create_usage_plan ( name = " Attached " )
2021-10-18 19:44:29 +00:00
client . create_usage_plan ( name = " Unattached " )
2018-10-17 12:44:00 +00:00
# Create an API key
# to attach to the usage plan
2019-10-31 15:44:26 +00:00
key_name = " test-api-key "
2018-10-17 12:44:00 +00:00
response = client . create_api_key ( name = key_name )
key_id = response [ " id " ]
# Create a Usage Plan Key
# Attached the Usage Plan and API Key
2019-10-31 15:44:26 +00:00
key_type = " API_KEY "
payload = { " usagePlanId " : attached_plan [ " id " ] , " keyId " : key_id , " keyType " : key_type }
2021-10-18 19:44:29 +00:00
client . create_usage_plan_key ( * * payload )
2018-10-17 12:44:00 +00:00
# All usage plans should be returned when keyId is not included
all_plans = client . get_usage_plans ( )
2023-06-07 09:46:18 +00:00
assert len ( all_plans [ " items " ] ) == 2
2018-10-17 12:44:00 +00:00
# Only the usage plan attached to the given api key are included
only_plans_with_key = client . get_usage_plans ( keyId = key_id )
2023-06-07 09:46:18 +00:00
assert len ( only_plans_with_key [ " items " ] ) == 1
assert only_plans_with_key [ " items " ] [ 0 ] [ " name " ] == attached_plan [ " name " ]
assert only_plans_with_key [ " items " ] [ 0 ] [ " id " ] == attached_plan [ " id " ]
2019-11-04 09:12:24 +00:00
def create_method_integration ( client , api_id , httpMethod = " GET " ) :
resources = client . get_resources ( restApiId = api_id )
root_id = [ resource for resource in resources [ " items " ] if resource [ " path " ] == " / " ] [
0
] [ " id " ]
client . put_method (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = httpMethod ,
authorizationType = " NONE " ,
)
client . put_method_response (
restApiId = api_id , resourceId = root_id , httpMethod = httpMethod , statusCode = " 200 "
)
client . put_integration (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = httpMethod ,
type = " HTTP " ,
uri = " http://httpbin.org/robots.txt " ,
integrationHttpMethod = " POST " ,
)
client . put_integration_response (
restApiId = api_id ,
resourceId = root_id ,
httpMethod = httpMethod ,
statusCode = " 200 " ,
responseTemplates = { } ,
)
2021-07-28 10:17:15 +00:00
return root_id
@mock_apigateway
def test_get_integration_response_unknown_response ( ) :
region_name = " us-west-2 "
client = boto3 . client ( " apigateway " , region_name = region_name )
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
root_id = create_method_integration ( client , api_id )
client . get_integration_response (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 200 "
)
with pytest . raises ( ClientError ) as ex :
client . get_integration_response (
restApiId = api_id , resourceId = root_id , httpMethod = " GET " , statusCode = " 300 "
)
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid Response status code specified "
assert err [ " Code " ] == " NotFoundException "
2021-07-28 10:17:15 +00:00
@mock_apigateway
def test_get_api_key_unknown_apikey ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-east-1 " )
with pytest . raises ( ClientError ) as ex :
client . get_api_key ( apiKey = " unknown " )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid API Key identifier specified "
assert err [ " Code " ] == " NotFoundException "
2021-07-28 10:17:15 +00:00
@mock_apigateway
def test_get_domain_name_unknown_domainname ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-east-1 " )
with pytest . raises ( ClientError ) as ex :
client . get_domain_name ( domainName = " www.google.com " )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid domain name identifier specified "
assert err [ " Code " ] == " NotFoundException "
2021-07-28 10:17:15 +00:00
@mock_apigateway
def test_delete_domain_name_unknown_domainname ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-east-1 " )
with pytest . raises ( ClientError ) as ex :
client . delete_domain_name ( domainName = " www.google.com " )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid domain name identifier specified "
assert err [ " Code " ] == " NotFoundException "
2021-10-27 10:48:32 +00:00
@mock_apigateway
def test_create_base_path_mapping ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
client . create_domain_name (
domainName = domain_name ,
certificateName = " test.certificate " ,
certificatePrivateKey = " testPrivateKey " ,
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
stage_name = " dev "
create_method_integration ( client , api_id )
client . create_deployment (
restApiId = api_id , stageName = stage_name , description = " 1.0.1 "
)
response = client . create_base_path_mapping ( domainName = domain_name , restApiId = api_id )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 201
assert response [ " basePath " ] == " (none) "
assert response [ " restApiId " ] == api_id
assert " stage " not in response
2021-10-27 10:48:32 +00:00
response = client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , stage = stage_name
)
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 201
assert response [ " basePath " ] == " (none) "
assert response [ " restApiId " ] == api_id
assert response [ " stage " ] == stage_name
2021-10-27 10:48:32 +00:00
response = client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , stage = stage_name , basePath = " v1 "
)
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 201
assert response [ " basePath " ] == " v1 "
assert response [ " restApiId " ] == api_id
assert response [ " stage " ] == stage_name
2021-10-27 10:48:32 +00:00
@mock_apigateway
def test_create_base_path_mapping_with_unknown_api ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
client . create_domain_name (
domainName = domain_name ,
certificateName = " test.certificate " ,
certificatePrivateKey = " testPrivateKey " ,
)
with pytest . raises ( ClientError ) as ex :
2023-06-07 09:46:18 +00:00
client . create_base_path_mapping ( domainName = domain_name , restApiId = " no " )
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid REST API identifier specified "
assert err [ " Code " ] == " BadRequestException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 400
2021-10-27 10:48:32 +00:00
@mock_apigateway
def test_create_base_path_mapping_with_invalid_base_path ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
client . create_domain_name (
domainName = domain_name ,
certificateName = " test.certificate " ,
certificatePrivateKey = " testPrivateKey " ,
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
stage_name = " dev "
create_method_integration ( client , api_id )
client . create_deployment (
restApiId = api_id , stageName = stage_name , description = " 1.0.1 "
)
with pytest . raises ( ClientError ) as ex :
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = " /v1 "
)
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert (
err [ " Message " ]
== " API Gateway V1 doesn ' t support the slash character (/) in base path mappings. To create a multi-level base path mapping, use API Gateway V2. "
2021-10-27 10:48:32 +00:00
)
2023-06-07 09:46:18 +00:00
assert err [ " Code " ] == " BadRequestException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 400
2021-10-27 10:48:32 +00:00
@mock_apigateway
def test_create_base_path_mapping_with_unknown_stage ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
client . create_domain_name (
domainName = domain_name ,
certificateName = " test.certificate " ,
certificatePrivateKey = " testPrivateKey " ,
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
stage_name = " dev "
create_method_integration ( client , api_id )
client . create_deployment (
restApiId = api_id , stageName = stage_name , description = " 1.0.1 "
)
with pytest . raises ( ClientError ) as ex :
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , stage = " unknown-stage "
)
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid stage identifier specified "
assert err [ " Code " ] == " BadRequestException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 400
2021-10-27 10:48:32 +00:00
@mock_apigateway
def test_create_base_path_mapping_with_duplicate_base_path ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
client . create_domain_name (
domainName = domain_name ,
certificateName = " test.certificate " ,
certificatePrivateKey = " testPrivateKey " ,
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
base_path = " v1 "
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = base_path
)
with pytest . raises ( ClientError ) as ex :
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = base_path
)
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Base path already exists for this domain name "
assert err [ " Code " ] == " ConflictException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 409
2021-10-29 09:54:12 +00:00
@mock_apigateway
def test_get_base_path_mappings ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
stage_name = " dev "
create_method_integration ( client , api_id )
client . create_deployment (
restApiId = api_id , stageName = stage_name , description = " 1.0.1 "
)
client . create_base_path_mapping ( domainName = domain_name , restApiId = api_id )
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = " v1 "
)
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = " v2 " , stage = stage_name
)
response = client . get_base_path_mappings ( domainName = domain_name )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 200
2021-10-29 09:54:12 +00:00
items = response [ " items " ]
2023-06-07 09:46:18 +00:00
assert items [ 0 ] [ " basePath " ] == " (none) "
assert items [ 0 ] [ " restApiId " ] == api_id
assert " stage " not in items [ 0 ]
2021-10-29 09:54:12 +00:00
2023-06-07 09:46:18 +00:00
assert items [ 1 ] [ " basePath " ] == " v1 "
assert items [ 1 ] [ " restApiId " ] == api_id
assert " stage " not in items [ 1 ]
2021-10-29 09:54:12 +00:00
2023-06-07 09:46:18 +00:00
assert items [ 2 ] [ " basePath " ] == " v2 "
assert items [ 2 ] [ " restApiId " ] == api_id
assert items [ 2 ] [ " stage " ] == stage_name
2021-10-29 09:54:12 +00:00
@mock_apigateway
def test_get_base_path_mappings_with_unknown_domain ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
with pytest . raises ( ClientError ) as ex :
client . get_base_path_mappings ( domainName = " unknown-domain " )
2023-06-07 09:46:18 +00:00
err = ex . value . response [ " Error " ]
assert err [ " Message " ] == " Invalid domain name identifier specified "
assert err [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-11-06 10:52:27 +00:00
@mock_apigateway
def test_get_base_path_mapping ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
stage_name = " dev "
create_method_integration ( client , api_id )
client . create_deployment (
restApiId = api_id , stageName = stage_name , description = " 1.0.1 "
)
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , stage = stage_name
)
response = client . get_base_path_mapping ( domainName = domain_name , basePath = " (none) " )
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 200
assert response [ " basePath " ] == " (none) "
assert response [ " restApiId " ] == api_id
assert response [ " stage " ] == stage_name
2021-11-06 10:52:27 +00:00
@mock_apigateway
def test_get_base_path_mapping_with_unknown_domain ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
with pytest . raises ( ClientError ) as ex :
client . get_base_path_mapping ( domainName = " unknown-domain " , basePath = " v1 " )
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid domain name identifier specified "
2021-11-06 10:52:27 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-11-06 10:52:27 +00:00
@mock_apigateway
def test_get_base_path_mapping_with_unknown_base_path ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = " v1 "
)
with pytest . raises ( ClientError ) as ex :
client . get_base_path_mapping ( domainName = domain_name , basePath = " unknown " )
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid base path mapping identifier specified "
2021-11-06 10:52:27 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-11-13 11:41:07 +00:00
@mock_apigateway
def test_delete_base_path_mapping ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
base_path = " v1 "
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = base_path
)
client . get_base_path_mapping ( domainName = domain_name , basePath = base_path )
response = client . delete_base_path_mapping (
domainName = domain_name , basePath = base_path
)
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 202
2021-11-13 11:41:07 +00:00
with pytest . raises ( ClientError ) as ex :
client . get_base_path_mapping ( domainName = domain_name , basePath = base_path )
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid base path mapping identifier specified "
2021-11-13 11:41:07 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-11-13 11:41:07 +00:00
@mock_apigateway
def test_delete_base_path_mapping_with_unknown_domain ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
with pytest . raises ( ClientError ) as ex :
client . delete_base_path_mapping ( domainName = " unknown-domain " , basePath = " v1 " )
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid domain name identifier specified "
2021-11-13 11:41:07 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-11-13 11:41:07 +00:00
@mock_apigateway
def test_delete_base_path_mapping_with_unknown_base_path ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = " v1 "
)
with pytest . raises ( ClientError ) as ex :
client . delete_base_path_mapping ( domainName = domain_name , basePath = " unknown " )
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid base path mapping identifier specified "
2021-11-13 11:41:07 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-12-30 10:52:57 +00:00
@mock_apigateway
def test_update_path_mapping ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
stage_name = " dev "
client . create_base_path_mapping ( domainName = domain_name , restApiId = api_id )
response = client . create_rest_api (
name = " new_my_api " , description = " this is new my api "
)
new_api_id = response [ " id " ]
create_method_integration ( client , new_api_id )
client . create_deployment (
restApiId = new_api_id , stageName = stage_name , description = " 1.0.1 "
)
base_path = " v1 "
patch_operations = [
{ " op " : " replace " , " path " : " /stage " , " value " : stage_name } ,
{ " op " : " replace " , " path " : " /basePath " , " value " : base_path } ,
{ " op " : " replace " , " path " : " /restapiId " , " value " : new_api_id } ,
]
response = client . update_base_path_mapping (
domainName = domain_name , basePath = " (none) " , patchOperations = patch_operations
)
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 200
assert response [ " basePath " ] == base_path
assert response [ " restApiId " ] == new_api_id
assert response [ " stage " ] == stage_name
2021-12-30 10:52:57 +00:00
@mock_apigateway
def test_update_path_mapping_with_unknown_domain ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
with pytest . raises ( ClientError ) as ex :
client . update_base_path_mapping (
domainName = " unknown-domain " , basePath = " (none) " , patchOperations = [ ]
)
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid domain name identifier specified "
2021-12-30 10:52:57 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-12-30 10:52:57 +00:00
@mock_apigateway
def test_update_path_mapping_with_unknown_base_path ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = " v1 "
)
with pytest . raises ( ClientError ) as ex :
client . update_base_path_mapping (
domainName = domain_name , basePath = " unknown " , patchOperations = [ ]
)
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ]
== " Invalid base path mapping identifier specified "
2021-12-30 10:52:57 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " NotFoundException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 404
2021-12-30 10:52:57 +00:00
@mock_apigateway
def test_update_path_mapping_to_same_base_path ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id_1 = response [ " id " ]
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id_2 = response [ " id " ]
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id_1 , basePath = " v1 "
)
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id_2 , basePath = " v2 "
)
response = client . get_base_path_mappings ( domainName = domain_name )
items = response [ " items " ]
2023-06-07 09:46:18 +00:00
assert len ( items ) == 2
2021-12-30 10:52:57 +00:00
patch_operations = [
{ " op " : " replace " , " path " : " /basePath " , " value " : " v2 " } ,
]
response = client . update_base_path_mapping (
domainName = domain_name , basePath = " v1 " , patchOperations = patch_operations
)
2023-06-07 09:46:18 +00:00
assert response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 200
assert response [ " basePath " ] == " v2 "
assert response [ " restApiId " ] == api_id_1
2021-12-30 10:52:57 +00:00
response = client . get_base_path_mappings ( domainName = domain_name )
items = response [ " items " ]
2023-06-07 09:46:18 +00:00
assert len ( items ) == 1
assert items [ 0 ] [ " basePath " ] == " v2 "
assert items [ 0 ] [ " restApiId " ] == api_id_1
assert " stage " not in items [ 0 ]
2021-12-30 10:52:57 +00:00
@mock_apigateway
def test_update_path_mapping_with_unknown_api ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
base_path = " v1 "
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = base_path
)
with pytest . raises ( ClientError ) as ex :
client . update_base_path_mapping (
domainName = domain_name ,
basePath = base_path ,
patchOperations = [
{ " op " : " replace " , " path " : " /restapiId " , " value " : " unknown " } ,
] ,
)
2023-06-07 09:46:18 +00:00
assert (
ex . value . response [ " Error " ] [ " Message " ] == " Invalid REST API identifier specified "
2021-12-30 10:52:57 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 400
2021-12-30 10:52:57 +00:00
@mock_apigateway
def test_update_path_mapping_with_unknown_stage ( ) :
client = boto3 . client ( " apigateway " , region_name = " us-west-2 " )
domain_name = " testDomain "
test_certificate_name = " test.certificate "
client . create_domain_name (
domainName = domain_name , certificateName = test_certificate_name
)
response = client . create_rest_api ( name = " my_api " , description = " this is my api " )
api_id = response [ " id " ]
base_path = " v1 "
client . create_base_path_mapping (
domainName = domain_name , restApiId = api_id , basePath = base_path
)
with pytest . raises ( ClientError ) as ex :
client . update_base_path_mapping (
domainName = domain_name ,
basePath = base_path ,
2022-03-10 14:39:59 +00:00
patchOperations = [ { " op " : " replace " , " path " : " /stage " , " value " : " unknown " } ] ,
2021-12-30 10:52:57 +00:00
)
2023-06-07 09:46:18 +00:00
assert ex . value . response [ " Error " ] [ " Message " ] == " Invalid stage identifier specified "
assert ex . value . response [ " Error " ] [ " Code " ] == " BadRequestException "
assert ex . value . response [ " ResponseMetadata " ] [ " HTTPStatusCode " ] == 400