From 27237693c3deb090e306a4accb40a36b7c0a2d88 Mon Sep 17 00:00:00 2001 From: John Newman Date: Tue, 8 Oct 2019 12:45:47 +0100 Subject: [PATCH 1/4] add tags to usage plan testing --- tests/test_apigateway/test_apigateway.py | 29 +++++++++++++++--------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/tests/test_apigateway/test_apigateway.py b/tests/test_apigateway/test_apigateway.py index 20cc078b8..42e9d7254 100644 --- a/tests/test_apigateway/test_apigateway.py +++ b/tests/test_apigateway/test_apigateway.py @@ -1029,20 +1029,27 @@ def test_usage_plans(): usage_plan['name'].should.equal(usage_plan_name) usage_plan['apiStages'].should.equal([]) - usage_plan_name = 'TEST-PLAN-2' - usage_plan_description = 'Description' - usage_plan_quota = {'limit': 10, 'period': 'DAY', 'offset': 0} - usage_plan_throttle = {'rateLimit': 2, 'burstLimit': 1} - usage_plan_api_stages = [{'apiId': 'foo', 'stage': 'bar'}] - payload = {'name': usage_plan_name, 'description': usage_plan_description, 'quota': usage_plan_quota, 'throttle': usage_plan_throttle, 'apiStages': usage_plan_api_stages} + 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'] usage_plan = client.get_usage_plan(usagePlanId=usage_plan_id) - usage_plan['name'].should.equal(usage_plan_name) - usage_plan['description'].should.equal(usage_plan_description) - usage_plan['apiStages'].should.equal(usage_plan_api_stages) - usage_plan['throttle'].should.equal(usage_plan_throttle) - usage_plan['quota'].should.equal(usage_plan_quota) + + # The payload should remain unchanged + for key, value in payload.items(): + usage_plan.should.have.key(key).which.should.equal(value) + + # Status code should be 200 + usage_plan['ResponseMetadata'].should.have.key('HTTPStatusCode').which.should.equal(200) + + # An Id should've been generated + usage_plan.should.have.key('id').which.should_not.be.none response = client.get_usage_plans() len(response['items']).should.equal(2) From 92b3898c2163276e507d62c924b333aec12705b4 Mon Sep 17 00:00:00 2001 From: John Newman Date: Tue, 8 Oct 2019 12:48:59 +0100 Subject: [PATCH 2/4] remove mutable default arg --- moto/apigateway/models.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/moto/apigateway/models.py b/moto/apigateway/models.py index 9d6305ef9..042ce84ac 100644 --- a/moto/apigateway/models.py +++ b/moto/apigateway/models.py @@ -332,13 +332,13 @@ class ApiKey(BaseModel, dict): class UsagePlan(BaseModel, dict): - def __init__(self, name=None, description=None, apiStages=[], + def __init__(self, name=None, description=None, apiStages=None, throttle=None, quota=None): super(UsagePlan, self).__init__() self['id'] = create_id() self['name'] = name self['description'] = description - self['apiStages'] = apiStages + self['apiStages'] = apiStages if apiStages else [] self['throttle'] = throttle self['quota'] = quota From bae1a313e14b94214285377993c95b279c160958 Mon Sep 17 00:00:00 2001 From: John Newman Date: Tue, 8 Oct 2019 12:49:44 +0100 Subject: [PATCH 3/4] add tags to UsagePlan --- moto/apigateway/models.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/moto/apigateway/models.py b/moto/apigateway/models.py index 042ce84ac..f0a4ffccf 100644 --- a/moto/apigateway/models.py +++ b/moto/apigateway/models.py @@ -333,7 +333,7 @@ class ApiKey(BaseModel, dict): class UsagePlan(BaseModel, dict): def __init__(self, name=None, description=None, apiStages=None, - throttle=None, quota=None): + throttle=None, quota=None, tags=None): super(UsagePlan, self).__init__() self['id'] = create_id() self['name'] = name @@ -341,7 +341,7 @@ class UsagePlan(BaseModel, dict): self['apiStages'] = apiStages if apiStages else [] self['throttle'] = throttle self['quota'] = quota - + self['tags'] = tags class UsagePlanKey(BaseModel, dict): From 2ba0134bb79c1458ce9a5473fe9ee2ad12bf68bd Mon Sep 17 00:00:00 2001 From: JPNewman89 Date: Tue, 8 Oct 2019 14:46:57 +0100 Subject: [PATCH 4/4] linting --- moto/apigateway/models.py | 1 + 1 file changed, 1 insertion(+) diff --git a/moto/apigateway/models.py b/moto/apigateway/models.py index f0a4ffccf..6f7fc97a9 100644 --- a/moto/apigateway/models.py +++ b/moto/apigateway/models.py @@ -343,6 +343,7 @@ class UsagePlan(BaseModel, dict): self['quota'] = quota self['tags'] = tags + class UsagePlanKey(BaseModel, dict): def __init__(self, id, type, name, value):