Merge "Add jsonschema validation for karbor verification API"

This commit is contained in:
Zuul 2017-12-19 09:44:34 +00:00 committed by Gerrit Code Review
commit 6e9b7d9ab2
3 changed files with 50 additions and 14 deletions

View File

@ -0,0 +1,38 @@
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
"""
Schema for Karbor V1 Verifications API.
"""
from karbor.api.validation import parameter_types
create = {
'type': 'object',
'properties': {
'type': 'object',
'verification': {
'type': 'object',
'properties': {
'provider_id': parameter_types.uuid,
'checkpoint_id': parameter_types.uuid,
'parameters': parameter_types.parameters,
},
'required': ['provider_id', 'checkpoint_id'],
'additionalProperties': False,
},
},
'required': ['verification'],
'additionalProperties': False,
}

View File

@ -20,6 +20,8 @@ from webob import exc
from karbor.api import common from karbor.api import common
from karbor.api.openstack import wsgi from karbor.api.openstack import wsgi
from karbor.api.schemas import verifications as verification_schema
from karbor.api import validation
from karbor.common import constants from karbor.common import constants
from karbor import exception from karbor import exception
from karbor.i18n import _ from karbor.i18n import _
@ -195,6 +197,7 @@ class VerificationsController(wsgi.Controller):
LOG.info("Get all verifications completed successfully.") LOG.info("Get all verifications completed successfully.")
return verifications return verifications
@validation.schema(verification_schema.create)
def create(self, req, body): def create(self, req, body):
"""Creates a new verification.""" """Creates a new verification."""
if not self.is_valid_body(body, 'verification'): if not self.is_valid_body(body, 'verification'):

View File

@ -16,7 +16,6 @@ from oslo_config import cfg
from webob import exc from webob import exc
from karbor.api.v1 import verifications from karbor.api.v1 import verifications
from karbor.common import constants
from karbor import context from karbor import context
from karbor import exception from karbor import exception
from karbor.tests import base from karbor.tests import base
@ -46,7 +45,7 @@ class VerificationApiTest(base.TestCase):
verification = self._verification_in_request_body() verification = self._verification_in_request_body()
body = {"verification": verification} body = {"verification": verification}
req = fakes.HTTPRequest.blank('/v1/verifications') req = fakes.HTTPRequest.blank('/v1/verifications')
self.controller.create(req, body) self.controller.create(req, body=body)
self.assertTrue(mock_verification_create.called) self.assertTrue(mock_verification_create.called)
self.assertTrue(mock_rpc_verification.called) self.assertTrue(mock_rpc_verification.called)
@ -54,25 +53,25 @@ class VerificationApiTest(base.TestCase):
verification = self._verification_in_request_body() verification = self._verification_in_request_body()
body = {"verificationxx": verification} body = {"verificationxx": verification}
req = fakes.HTTPRequest.blank('/v1/verifications') req = fakes.HTTPRequest.blank('/v1/verifications')
self.assertRaises(exc.HTTPUnprocessableEntity, self.assertRaises(exception.ValidationError,
self.controller.create, self.controller.create,
req, body) req, body=body)
def test_verification_create_InvalidProviderId(self): def test_verification_create_InvalidProviderId(self):
verification = self._verification_in_request_body( verification = self._verification_in_request_body(
provider_id="") provider_id="")
body = {"verification": verification} body = {"verification": verification}
req = fakes.HTTPRequest.blank('/v1/verifications') req = fakes.HTTPRequest.blank('/v1/verifications')
self.assertRaises(exception.InvalidInput, self.controller.create, self.assertRaises(exception.ValidationError, self.controller.create,
req, body) req, body=body)
def test_verification_create_Invalidcheckpoint_id(self): def test_verification_create_Invalidcheckpoint_id(self):
verification = self._verification_in_request_body( verification = self._verification_in_request_body(
checkpoint_id="") checkpoint_id="")
body = {"verification": verification} body = {"verification": verification}
req = fakes.HTTPRequest.blank('/v1/verifications') req = fakes.HTTPRequest.blank('/v1/verifications')
self.assertRaises(exception.InvalidInput, self.controller.create, self.assertRaises(exception.ValidationError, self.controller.create,
req, body) req, body=body)
@mock.patch( @mock.patch(
'karbor.api.v1.verifications.' 'karbor.api.v1.verifications.'
@ -98,17 +97,13 @@ class VerificationApiTest(base.TestCase):
req, "1") req, "1")
def _verification_in_request_body( def _verification_in_request_body(
self, project_id=DEFAULT_PROJECT_ID, self, provider_id=DEFAULT_PROVIDER_ID,
provider_id=DEFAULT_PROVIDER_ID,
checkpoint_id=DEFAULT_CHECKPOINT_ID, checkpoint_id=DEFAULT_CHECKPOINT_ID,
parameters=DEFAULT_PARAMETERS, parameters=DEFAULT_PARAMETERS):
status=constants.RESOURCE_STATUS_STARTED):
verification_req = { verification_req = {
'project_id': project_id,
'provider_id': provider_id, 'provider_id': provider_id,
'checkpoint_id': checkpoint_id, 'checkpoint_id': checkpoint_id,
'parameters': parameters, 'parameters': parameters,
'status': status,
} }
return verification_req return verification_req