V1 Tests JsonSchema
Refactored V1 tests to include JsonSchema validation where appropriate Added necessary schema entries to the schema dictionary Implements: blueprint jsonschema-validation Change-Id: I474265948253a932ef3dbb45bca34b27b798447d
This commit is contained in:
parent
74eb5eb77a
commit
a4c43eae01
marconi/queues/api/v1
tests/functional/wsgi/v1
@ -22,37 +22,43 @@ class ResponseSchema(api.Api):
|
||||
|
||||
def __init__(self, limits):
|
||||
self.limits = limits
|
||||
self.schema = {
|
||||
'message_get_many': {
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "object",
|
||||
"properties": {
|
||||
"href": {
|
||||
"type": "string",
|
||||
"pattern": "^(/v1/queues/[a-zA-Z0-9_-]{1,64}"
|
||||
"/messages/[a-zA-Z0-9_-]+)$"
|
||||
},
|
||||
"ttl": {
|
||||
"type": "number",
|
||||
"minimum": 1,
|
||||
"maximum": self.limits.max_message_ttl
|
||||
},
|
||||
"age": {
|
||||
"type": "number",
|
||||
"minimum": 0
|
||||
},
|
||||
"body": {
|
||||
"type": "object"
|
||||
}
|
||||
},
|
||||
"required": ["href", "ttl", "age", "body"],
|
||||
"additionalProperties": False,
|
||||
},
|
||||
"minItems": 1,
|
||||
"maxItems": self.limits.max_messages_per_page
|
||||
},
|
||||
|
||||
age = {
|
||||
"type": "number",
|
||||
"minimum": 0
|
||||
}
|
||||
|
||||
message = {
|
||||
"type": "object",
|
||||
"properties": {
|
||||
"href": {
|
||||
"type": "string",
|
||||
"pattern": "^(/v1/queues/[a-zA-Z0-9_-]"
|
||||
"{1,64}/messages/[a-zA-Z0-9_-]+)$"
|
||||
},
|
||||
"age": age,
|
||||
"ttl": {
|
||||
"type": "number",
|
||||
"minimum": 1,
|
||||
"maximum": self.limits.max_message_ttl
|
||||
},
|
||||
|
||||
"body": {
|
||||
"type": "object"
|
||||
}
|
||||
},
|
||||
"required": ["href", "ttl", "age", "body"],
|
||||
"additionalProperties": False,
|
||||
}
|
||||
|
||||
claim_href = {
|
||||
"type": "string",
|
||||
"pattern": "^(/v1/queues/[a-zA-Z0-9_-]{1,64}"
|
||||
"/messages/[a-zA-Z0-9_-]+)"
|
||||
"\?claim_id=[a-zA-Z0-9_-]+$"
|
||||
}
|
||||
|
||||
self.schema = {
|
||||
'queue_list': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
@ -103,5 +109,137 @@ class ResponseSchema(api.Api):
|
||||
},
|
||||
'required': ['links', 'queues'],
|
||||
'additionalProperties': False,
|
||||
},
|
||||
'queue_stats': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'messages': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'free': {
|
||||
'type': 'number',
|
||||
'minimum': 0
|
||||
},
|
||||
'claimed': {
|
||||
'type': 'number',
|
||||
'minimum': 0
|
||||
},
|
||||
'total': {
|
||||
'type': 'number',
|
||||
'minimum': 0
|
||||
},
|
||||
'oldest': {
|
||||
'type': 'object'
|
||||
},
|
||||
'newest': {
|
||||
'type': 'object'
|
||||
}
|
||||
|
||||
},
|
||||
'required': ['free', 'claimed', 'total'],
|
||||
'additionalProperties': False
|
||||
}
|
||||
},
|
||||
'required': ['messages'],
|
||||
'additionalProperties': False
|
||||
},
|
||||
'message_list': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'links': {
|
||||
'type': 'array',
|
||||
'items': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'rel': {
|
||||
'type': 'string'
|
||||
},
|
||||
'href': {
|
||||
'type': 'string',
|
||||
'pattern': '^/v1/queues/[a-zA-Z0-9_-]+'
|
||||
'/messages\?(.)*$'
|
||||
}
|
||||
},
|
||||
'required': ['rel', 'href'],
|
||||
'additionalProperties': False
|
||||
}
|
||||
},
|
||||
'messages': {
|
||||
"type": "array",
|
||||
"items": message,
|
||||
"minItems": 1,
|
||||
"maxItems": self.limits.max_messages_per_claim
|
||||
}
|
||||
}
|
||||
},
|
||||
'message_get_many': {
|
||||
"type": "array",
|
||||
"items": message,
|
||||
"minItems": 1,
|
||||
"maxItems": self.limits.max_messages_per_page
|
||||
},
|
||||
|
||||
'claim_create': {
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "object",
|
||||
"properties": {
|
||||
"href": claim_href,
|
||||
"ttl": {
|
||||
"type": "number",
|
||||
"minimum": 1,
|
||||
"maximum": self.limits.max_message_ttl
|
||||
},
|
||||
"age": age,
|
||||
"body": {
|
||||
"type": "object"
|
||||
}
|
||||
},
|
||||
"required": ["href", "ttl", "age", "body"],
|
||||
"additionalProperties": False,
|
||||
},
|
||||
"minItems": 1,
|
||||
"maxItems": self.limits.max_messages_per_page
|
||||
},
|
||||
|
||||
'claim_get': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'age': age,
|
||||
'ttl': {
|
||||
'type': 'number',
|
||||
'minimum': 0,
|
||||
'maximum': self.limits.max_claim_ttl
|
||||
},
|
||||
'href': {
|
||||
'type': 'string',
|
||||
'pattern': '^/v1/queues/[a-zA-Z0-9_-]+'
|
||||
'/claims/[a-zA-Z0-9_-]+$'
|
||||
},
|
||||
'messages': {
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "object",
|
||||
"properties": {
|
||||
"href": claim_href,
|
||||
"ttl": {
|
||||
"type": "number",
|
||||
"minimum": 1,
|
||||
"maximum": self.limits.max_message_ttl
|
||||
},
|
||||
"age": age,
|
||||
"body": {
|
||||
"type": "object"
|
||||
}
|
||||
},
|
||||
"required": ["href", "ttl", "age", "body"],
|
||||
"additionalProperties": False,
|
||||
},
|
||||
"minItems": 1,
|
||||
"maxItems": self.limits.max_messages_per_page
|
||||
}
|
||||
},
|
||||
'required': ['age', 'ttl', 'messages', 'href'],
|
||||
'additionalProperties': False
|
||||
}
|
||||
}
|
||||
|
@ -52,7 +52,8 @@ class TestClaims(base.FunctionalTestBase):
|
||||
@ddt.data({}, dict(limit=2))
|
||||
def test_claim_messages(self, params):
|
||||
"""Claim messages."""
|
||||
message_count = params.get('limit', 10)
|
||||
message_count = params.get('limit',
|
||||
self.limits.max_messages_per_claim)
|
||||
|
||||
doc = {"ttl": 300, "grace": 100}
|
||||
|
||||
@ -65,6 +66,9 @@ class TestClaims(base.FunctionalTestBase):
|
||||
response_headers = set(result.headers.keys())
|
||||
self.assertIsSubset(self.headers_response_with_body, response_headers)
|
||||
|
||||
# NOTE(abettadapur) This fails because of Bug #1321840
|
||||
# self.assertSchema(result.json(), 'claim_create')
|
||||
|
||||
test_claim_messages.tags = ['smoke', 'positive']
|
||||
|
||||
def test_query_claim(self):
|
||||
@ -80,6 +84,9 @@ class TestClaims(base.FunctionalTestBase):
|
||||
result = self.client.get(url)
|
||||
self.assertEqual(result.status_code, 200)
|
||||
|
||||
# NOTE(abettadapur) This fails because of Bug #1321840
|
||||
# self.assertSchema(result.json(), 'claim_get')
|
||||
|
||||
test_query_claim.tags = ['smoke', 'positive']
|
||||
|
||||
def test_claim_more_than_allowed(self):
|
||||
|
@ -137,7 +137,7 @@ class TestMessages(base.FunctionalTestBase):
|
||||
|
||||
test_message_bulk_insert.tags = ['smoke', 'positive']
|
||||
|
||||
@ddt.data({}, {'limit': 5})
|
||||
@ddt.data({'limit': 10}, {'limit': 5})
|
||||
def test_get_message(self, params):
|
||||
"""Get Messages."""
|
||||
|
||||
@ -161,6 +161,7 @@ class TestMessages(base.FunctionalTestBase):
|
||||
if result.status_code == 200:
|
||||
actual_msg_count = len(result.json()['messages'])
|
||||
self.assertMessageCount(actual_msg_count, expected_msg_count)
|
||||
self.assertSchema(result.json(), 'message_list')
|
||||
|
||||
href = result.json()['links'][0]['href']
|
||||
url = self.cfg.marconi.url + href
|
||||
@ -244,6 +245,7 @@ class TestMessages(base.FunctionalTestBase):
|
||||
url += ',nonexisting'
|
||||
result = self.client.get(url)
|
||||
self.assertEqual(result.status_code, 200)
|
||||
self.assertSchema(result.json(), "message_get_many")
|
||||
|
||||
test_message_partial_get.tags = ['negative']
|
||||
|
||||
|
@ -369,6 +369,7 @@ class TestQueueMisc(base.FunctionalTestBase):
|
||||
expected_response = {'messages':
|
||||
{'claimed': 0, 'total': 0, 'free': 0}}
|
||||
self.assertEqual(result.json(), expected_response)
|
||||
self.assertSchema(result.json(), 'queue_stats')
|
||||
|
||||
test_get_stats_empty_queue.tags = ['positive']
|
||||
|
||||
@ -399,6 +400,7 @@ class TestQueueMisc(base.FunctionalTestBase):
|
||||
self.assertEqual(result.status_code, 200)
|
||||
|
||||
self.assertQueueStats(result.json(), claimed)
|
||||
self.assertSchema(result.json(), 'queue_stats')
|
||||
|
||||
test_get_queue_stats_claimed.tags = ['positive']
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user