Merge pull request #109 from diogobaeder/master

Accepting uuid string format and validating accordingly.
This commit is contained in:
A 2019-02-26 14:30:19 +00:00 committed by GitHub
commit 23118296ab
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 32 additions and 1 deletions

View file

@ -25,3 +25,4 @@ class SchemaFormat(Enum):
DATE = 'date' DATE = 'date'
DATETIME = 'date-time' DATETIME = 'date-time'
PASSWORD = 'password' PASSWORD = 'password'
UUID = 'uuid'

View file

@ -8,6 +8,7 @@ import re
import warnings import warnings
from six import iteritems, integer_types, binary_type, text_type from six import iteritems, integer_types, binary_type, text_type
from uuid import UUID
from openapi_core.extensions.models.factories import ModelFactory from openapi_core.extensions.models.factories import ModelFactory
from openapi_core.schema.schemas.enums import SchemaFormat, SchemaType from openapi_core.schema.schemas.enums import SchemaFormat, SchemaType
@ -46,6 +47,7 @@ class Schema(object):
SchemaFormat.DATE: Format(format_date, TypeValidator(date, exclude=datetime)), SchemaFormat.DATE: Format(format_date, TypeValidator(date, exclude=datetime)),
SchemaFormat.DATETIME: Format(format_datetime, TypeValidator(datetime)), SchemaFormat.DATETIME: Format(format_datetime, TypeValidator(datetime)),
SchemaFormat.BINARY: Format(binary_type, TypeValidator(binary_type)), SchemaFormat.BINARY: Format(binary_type, TypeValidator(binary_type)),
SchemaFormat.UUID: Format(UUID, TypeValidator(UUID)),
} }
TYPE_VALIDATOR_CALLABLE_GETTER = { TYPE_VALIDATOR_CALLABLE_GETTER = {
@ -54,7 +56,7 @@ class Schema(object):
SchemaType.INTEGER: TypeValidator(integer_types, exclude=bool), SchemaType.INTEGER: TypeValidator(integer_types, exclude=bool),
SchemaType.NUMBER: TypeValidator(integer_types, float, exclude=bool), SchemaType.NUMBER: TypeValidator(integer_types, float, exclude=bool),
SchemaType.STRING: TypeValidator( SchemaType.STRING: TypeValidator(
text_type, date, datetime, binary_type), text_type, date, datetime, binary_type, UUID),
SchemaType.ARRAY: TypeValidator(list, tuple), SchemaType.ARRAY: TypeValidator(list, tuple),
SchemaType.OBJECT: AttributeValidator('__dict__'), SchemaType.OBJECT: AttributeValidator('__dict__'),
} }

View file

@ -317,6 +317,9 @@ components:
required: required:
- rootCause - rootCause
properties: properties:
correlationId:
type: string
format: uuid
rootCause: rootCause:
type: string type: string
suberror: suberror:

View file

@ -1,5 +1,6 @@
import json import json
import pytest import pytest
from uuid import UUID
from six import iteritems from six import iteritems
from openapi_core.extensions.models.models import BaseModel from openapi_core.extensions.models.models import BaseModel
@ -1154,11 +1155,13 @@ class TestPetstore(object):
code = 400 code = 400
message = 'Bad request' message = 'Bad request'
correlationId = UUID('a8098c1a-f86e-11da-bd1a-00112444be1e')
rootCause = 'Tag already exist' rootCause = 'Tag already exist'
additionalinfo = 'Tag Dog already exist' additionalinfo = 'Tag Dog already exist'
data_json = { data_json = {
'code': code, 'code': code,
'message': message, 'message': message,
'correlationId': str(correlationId),
'rootCause': rootCause, 'rootCause': rootCause,
'additionalinfo': additionalinfo, 'additionalinfo': additionalinfo,
} }
@ -1171,5 +1174,6 @@ class TestPetstore(object):
assert isinstance(response_result.data, BaseModel) assert isinstance(response_result.data, BaseModel)
assert response_result.data.code == code assert response_result.data.code == code
assert response_result.data.message == message assert response_result.data.message == message
assert response_result.data.correlationId == correlationId
assert response_result.data.rootCause == rootCause assert response_result.data.rootCause == rootCause
assert response_result.data.additionalinfo == additionalinfo assert response_result.data.additionalinfo == additionalinfo

View file

@ -1,4 +1,5 @@
import datetime import datetime
import uuid
import mock import mock
import pytest import pytest
@ -416,6 +417,26 @@ class TestSchemaValidate(object):
assert result == value assert result == value
@pytest.mark.parametrize('value', [
uuid.UUID('{12345678-1234-5678-1234-567812345678}'),
])
def test_string_format_uuid(self, value):
schema = Schema('string', schema_format='uuid')
result = schema.validate(value)
assert result == value
@pytest.mark.parametrize('value', [
b('true'), u('true'), False, 1, 3.14, [1, 3],
datetime.date(2018, 1, 2), datetime.datetime(2018, 1, 2, 23, 59, 59),
])
def test_string_format_uuid_invalid(self, value):
schema = Schema('string', schema_format='uuid')
with pytest.raises(InvalidSchemaValue):
schema.validate(value)
@pytest.mark.parametrize('value', [ @pytest.mark.parametrize('value', [
b('true'), u('true'), False, 1, 3.14, [1, 3], b('true'), u('true'), False, 1, 3.14, [1, 3],
datetime.date(1989, 1, 2), datetime.date(1989, 1, 2),