Refactoring to make Websocket driver available in v2

Considering that most of this feature landed during the Liberty
cycle, it made sense to make Websocket a v2 feature.

APIImpact
Implements-blueprint: persistent-transport
Change-Id: I52ef38f32afd688239d4aee9ac379cd8dea03d6c
This commit is contained in:
Victoria Martinez de la Cruz 2015-08-28 16:25:12 -03:00 committed by Flavio Percoco
parent 8e8adb16c4
commit 761d23dc65
16 changed files with 827 additions and 553 deletions

View File

@ -1,7 +0,0 @@
The :mod:`zaqar.api.v1_1.endpoints` module
===========================================
.. automodule:: zaqar.api.v1_1.endpoints
:members:
:undoc-members:
:show-inheritance:

View File

@ -0,0 +1,7 @@
The :mod:`zaqar.api.v2.endpoints` module
=========================================
.. automodule:: zaqar.api.v2.endpoints
:members:
:undoc-members:
:show-inheritance:

View File

@ -0,0 +1,7 @@
The :mod:`zaqar.api.v2.request` module
=======================================
.. automodule:: zaqar.api.v2.request
:members:
:undoc-members:
:show-inheritance:

View File

@ -0,0 +1,7 @@
The :mod:`zaqar.api.v2.response` module
========================================
.. automodule:: zaqar.api.v2.response
:members:
:undoc-members:
:show-inheritance:

View File

@ -12,8 +12,8 @@
# License for the specific language governing permissions and limitations under # License for the specific language governing permissions and limitations under
# the License. # the License.
from zaqar.api.v1_1 import endpoints from zaqar.api.v2 import endpoints
from zaqar.api.v1_1 import request as schema_validator from zaqar.api.v2 import request as schema_validator
from zaqar.common.api import request from zaqar.common.api import request
from zaqar.common.api import response from zaqar.common.api import response
@ -37,12 +37,12 @@ class Handler(object):
} }
def __init__(self, storage, control, validate, defaults): def __init__(self, storage, control, validate, defaults):
self.v1_1_endpoints = endpoints.Endpoints(storage, control, self.v2_endpoints = endpoints.Endpoints(storage, control,
validate, defaults) validate, defaults)
def process_request(self, req): def process_request(self, req):
# FIXME(vkmc): Control API version # FIXME(vkmc): Control API version
return getattr(self.v1_1_endpoints, req._action)(req) return getattr(self.v2_endpoints, req._action)(req)
@staticmethod @staticmethod
def validate_request(payload, req): def validate_request(payload, req):
@ -79,10 +79,10 @@ class Handler(object):
headers = payload.get('headers') headers = payload.get('headers')
return request.Request(action=action, body=body, return request.Request(action=action, body=body,
headers=headers, api="v1.1") headers=headers, api="v2")
def get_defaults(self): def get_defaults(self):
return self.v1_1_endpoints._defaults return self.v2_endpoints._defaults
def verify_signature(self, key, payload): def verify_signature(self, key, payload):
action = payload.get('action') action = payload.get('action')

View File

@ -18,180 +18,369 @@ from zaqar.common.api import api
class RequestSchema(api.Api): class RequestSchema(api.Api):
headers = {
'User-Agent': {'type': 'string'},
'Date': {'type': 'string'},
'Accept': {'type': 'string'},
'Client-ID': {'type': 'string'},
'X-Project-ID': {'type': 'string'},
'X-Auth-Token': {'type': 'string'}
}
schema = { schema = {
# Base
'get_home_doc': {
'properties': {
'action': {'enum': ['get_home_doc']},
'headers': {
'type': 'object',
'properties': headers,
}
},
'required': ['action', 'headers'],
'admin': True,
},
'check_node_health': {
'properties': {
'action': {'enum': ['check_node_health']},
'headers': {
'type': 'object',
'properties': headers,
}
},
'required': ['action', 'headers'],
'admin': True,
},
'ping_node': {
'properties': {
'action': {'enum': ['ping_node']},
'headers': {
'type': 'object',
'properties': headers,
}
},
'required': ['action', 'headers'],
'admin': True,
},
'authenticate': {
'properties': {
'action': {'enum': ['authenticate']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['X-Project-ID', 'X-Auth-Token']
}
},
'required': ['action', 'headers'],
},
# Queues
'queue_list': { 'queue_list': {
'ref': 'queues', 'properties': {
'method': 'GET', 'action': {'enum': ['queue_list']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'marker': {'type': 'string'}, 'marker': {'type': 'string'},
'limit': {'type': 'integer'}, 'limit': {'type': 'integer'},
'detailed': {'type': 'boolean'} 'detailed': {'type': 'boolean'}
} }
}
},
'required': ['action', 'headers']
}, },
'queue_create': { 'queue_create': {
'ref': 'queues/{queue_name}',
'method': 'PUT',
'required': ['queue_name'],
'properties': { 'properties': {
'queue_name': {'type': 'string'} 'action': {'enum': ['queue_create']},
}, 'headers': {
}, 'type': 'object',
'properties': headers,
'queue_exists': { 'required': ['Client-ID', 'X-Project-ID']},
'ref': 'queues/{queue_name}', 'body': {
'method': 'HEAD', 'type': 'object',
'required': ['queue_name'],
'properties': { 'properties': {
'queue_name': {'type': 'string'} 'queue_name': {'type': 'string'},
},
'required': ['queue_name'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'queue_delete': { 'queue_delete': {
'ref': 'queues/{queue_name}',
'method': 'DELETE',
'required': ['queue_name'],
'properties': { 'properties': {
'queue_name': {'type': 'string'} 'action': {'enum': ['queue_delete']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
},
'required': ['queue_name']
} }
}, },
'required': ['action', 'headers', 'body']
'queue_set_metadata': {
'ref': 'queues/{queue_name}/metadata',
'method': 'PUT',
'required': ['queue_name'],
'properties': {
# NOTE(flaper87): Metadata is part
# of the request content. No need to
# add it here.
'queue_name': {'type': 'string'}
}
}, },
'queue_get_metadata': { 'queue_get': {
'ref': 'queues/{queue_name}/metadata',
'method': 'GET',
'required': ['queue_name'],
'properties': { 'properties': {
'queue_name': {'type': 'string'} 'action': {'enum': ['queue_get']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
},
'required': ['queue_name'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'queue_get_stats': { 'queue_get_stats': {
'ref': 'queues/{queue_name}/stats', 'properties': {
'method': 'GET', 'action': {'enum': ['queue_get_stats']},
'required': ['queue_name'], 'headers': {
'admin': True, 'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
},
'required': ['queue_name'],
} }
}, },
'required': ['action', 'headers', 'body'],
'admin': True
},
# Messages
'message_list': { 'message_list': {
'ref': 'queues/{queue_name}/messages', 'properties': {
'method': 'GET', 'action': {'enum': ['message_list']},
'required': ['queue_name'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'marker': {'type': 'string'}, 'marker': {'type': 'string'},
'limit': {'type': 'integer'}, 'limit': {'type': 'integer'},
'echo': {'type': 'boolean'}, 'echo': {'type': 'boolean'},
'include_claimed': {'type': 'boolean'} 'include_claimed': {'type': 'boolean'},
},
'required': ['queue_name'],
} }
}, },
'required': ['action', 'headers', 'body']
'message_post': {
'ref': 'queues/{queue_name}/messages',
'method': 'POST',
'required': ['queue_name'],
'properties': {
'queue_name': {'type': 'string'}
}
}, },
'message_get': { 'message_get': {
'ref': 'queues/{queue_name}/messages/{message_id}', 'properties': {
'method': 'GET', 'action': {'enum': ['message_get']},
'required': ['queue_name', 'message_id'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'message_id': {'type': 'string'} 'message_id': {'type': 'string'},
},
'required': ['queue_name', 'message_id'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'message_get_many': { 'message_get_many': {
'ref': 'queues/{queue_name}/messages', 'properties': {
'method': 'GET', 'action': {'enum': ['message_get_many']},
'required': ['queue_name', 'ids'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'ids': {'type': 'array'} 'message_ids': {'type': 'array'},
},
'required': ['queue_name', 'message_ids'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'message_post': {
'properties': {
'action': {'enum': ['message_post']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'messages': {'type': 'array'},
},
'required': ['queue_name', 'messages'],
}
},
'required': ['action', 'headers', 'body']
},
'message_delete': { 'message_delete': {
'ref': 'queues/{queue_name}/messages/{message_id}', 'properties': {
'method': 'DELETE', 'action': {'enum': ['message_delete']},
'required': ['queue_name', 'message_id'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'message_id': {'type': 'string'}, 'message_id': {'type': 'string'},
'claim_id': {'type': 'string'} 'claim_id': {'type': 'string'}
},
'required': ['queue_name', 'message_id'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'message_delete_many': { 'message_delete_many': {
'ref': 'queues/{queue_name}/messages', 'properties': {
'method': 'DELETE', 'action': {'enum': ['message_delete_many']},
'required': ['queue_name', 'ids'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'ids': {'type': 'array'} 'message_ids': {'type': 'array'},
'pop': {'type': 'integer'}
},
'required': ['queue_name', 'message_ids'],
} }
}, },
'required': ['action', 'headers', 'body']
},
# Claims
'claim_create': { 'claim_create': {
'ref': 'queues/{queue_name}/claims', 'properties': {
'method': 'POST', 'action': {'enum': ['claim_create']},
'required': ['queue_name'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'limit': {'type': 'integer'} 'limit': {'type': 'integer'},
'ttl': {'type': 'integer'},
'grace': {'type': 'integer'}
},
'required': ['queue_name'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'claim_get': { 'claim_get': {
'ref': 'queues/{queue_name}/claims/{claim_id}', 'properties': {
'method': 'GET', 'action': {'enum': ['claim_get']},
'required': ['queue_name', 'claim_id'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'claim_id': {'type': 'string'} 'claim_id': {'type': 'string'}
},
'required': ['queue_name', 'claim_id'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'claim_update': { 'claim_update': {
'ref': 'queues/{queue_name}/claims/{claim_id}', 'properties': {
'method': 'PATCH', 'action': {'enum': ['claim_update']},
'required': ['queue_name', 'claim_id'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'claim_id': {'type': 'string'} 'claim_id': {'type': 'string'},
'ttl': {'type': 'integer'}
},
'required': ['queue_name', 'claim_id'],
} }
}, },
'required': ['action', 'headers', 'body']
},
'claim_delete': { 'claim_delete': {
'ref': 'queues/{queue_name}/claims/{claim_id}', 'properties': {
'method': 'DELETE', 'action': {'enum': ['claim_delete']},
'required': ['queue_name', 'claim_id'], 'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': { 'properties': {
'queue_name': {'type': 'string'}, 'queue_name': {'type': 'string'},
'claim_id': {'type': 'string'} 'claim_id': {'type': 'string'}
},
'required': ['queue_name', 'claim_id'],
} }
}, },
'required': ['action', 'headers', 'body']
'check_node_health': {
'ref': '/v1/health',
'method': 'GET',
}, },
} }

View File

@ -13,376 +13,15 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
from zaqar.common.api import api from zaqar.api.v1 import request as v1
class RequestSchema(api.Api): class RequestSchema(v1.RequestSchema):
headers = { headers = v1.RequestSchema.headers
'User-Agent': {'type': 'string'}, schema = v1.RequestSchema.schema
'Date': {'type': 'string'},
'Accept': {'type': 'string'},
'Client-ID': {'type': 'string'},
'X-Project-ID': {'type': 'string'},
'X-Auth-Token': {'type': 'string'}
}
schema = { schema.update({
# Base
'get_home_doc': {
'properties': {
'action': {'enum': ['get_home_doc']},
'headers': {
'type': 'object',
'properties': headers,
}
},
'required': ['action', 'headers'],
'admin': True,
},
'check_node_health': {
'properties': {
'action': {'enum': ['check_node_health']},
'headers': {
'type': 'object',
'properties': headers,
}
},
'required': ['action', 'headers'],
'admin': True,
},
'ping_node': {
'properties': {
'action': {'enum': ['ping_node']},
'headers': {
'type': 'object',
'properties': headers,
}
},
'required': ['action', 'headers'],
'admin': True,
},
'authenticate': {
'properties': {
'action': {'enum': ['authenticate']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['X-Project-ID', 'X-Auth-Token']
}
},
'required': ['action', 'headers'],
},
# Queues
'queue_list': {
'properties': {
'action': {'enum': ['queue_list']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'marker': {'type': 'string'},
'limit': {'type': 'integer'},
'detailed': {'type': 'boolean'}
}
}
},
'required': ['action', 'headers']
},
'queue_create': {
'properties': {
'action': {'enum': ['queue_create']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
},
'required': ['queue_name'],
}
},
'required': ['action', 'headers', 'body']
},
'queue_delete': {
'properties': {
'action': {'enum': ['queue_delete']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
},
'required': ['queue_name']
}
},
'required': ['action', 'headers', 'body']
},
'queue_get': {
'properties': {
'action': {'enum': ['queue_get']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
},
'required': ['queue_name'],
}
},
'required': ['action', 'headers', 'body']
},
'queue_get_stats': {
'properties': {
'action': {'enum': ['queue_get_stats']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
},
'required': ['queue_name'],
}
},
'required': ['action', 'headers', 'body'],
'admin': True
},
# Messages
'message_list': {
'properties': {
'action': {'enum': ['message_list']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'marker': {'type': 'string'},
'limit': {'type': 'integer'},
'echo': {'type': 'boolean'},
'include_claimed': {'type': 'boolean'},
},
'required': ['queue_name'],
}
},
'required': ['action', 'headers', 'body']
},
'message_get': {
'properties': {
'action': {'enum': ['message_get']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'message_id': {'type': 'string'},
},
'required': ['queue_name', 'message_id'],
}
},
'required': ['action', 'headers', 'body']
},
'message_get_many': {
'properties': {
'action': {'enum': ['message_get_many']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'message_ids': {'type': 'array'},
},
'required': ['queue_name', 'message_ids'],
}
},
'required': ['action', 'headers', 'body']
},
'message_post': {
'properties': {
'action': {'enum': ['message_post']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'messages': {'type': 'array'},
},
'required': ['queue_name', 'messages'],
}
},
'required': ['action', 'headers', 'body']
},
'message_delete': {
'properties': {
'action': {'enum': ['message_delete']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'message_id': {'type': 'string'},
'claim_id': {'type': 'string'}
},
'required': ['queue_name', 'message_id'],
}
},
'required': ['action', 'headers', 'body']
},
'message_delete_many': {
'properties': {
'action': {'enum': ['message_delete_many']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'message_ids': {'type': 'array'},
'pop': {'type': 'integer'}
},
'required': ['queue_name', 'message_ids'],
}
},
'required': ['action', 'headers', 'body']
},
# Claims
'claim_create': {
'properties': {
'action': {'enum': ['claim_create']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'limit': {'type': 'integer'},
'ttl': {'type': 'integer'},
'grace': {'type': 'integer'}
},
'required': ['queue_name'],
}
},
'required': ['action', 'headers', 'body']
},
'claim_get': {
'properties': {
'action': {'enum': ['claim_get']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'claim_id': {'type': 'string'}
},
'required': ['queue_name', 'claim_id'],
}
},
'required': ['action', 'headers', 'body']
},
'claim_update': {
'properties': {
'action': {'enum': ['claim_update']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'claim_id': {'type': 'string'},
'ttl': {'type': 'integer'}
},
'required': ['queue_name', 'claim_id'],
}
},
'required': ['action', 'headers', 'body']
},
'claim_delete': {
'properties': {
'action': {'enum': ['claim_delete']},
'headers': {
'type': 'object',
'properties': headers,
'required': ['Client-ID', 'X-Project-ID']
},
'body': {
'type': 'object',
'properties': {
'queue_name': {'type': 'string'},
'claim_id': {'type': 'string'}
},
'required': ['queue_name', 'claim_id'],
}
},
'required': ['action', 'headers', 'body']
},
# Pools # Pools
'pool_list': { 'pool_list': {
@ -601,4 +240,4 @@ class RequestSchema(api.Api):
'required': ['action', 'headers', 'body'], 'required': ['action', 'headers', 'body'],
'admin': True, 'admin': True,
}, },
} })

View File

@ -25,7 +25,7 @@ LOG = logging.getLogger(__name__)
class Endpoints(object): class Endpoints(object):
"""v1.1 API Endpoints.""" """v2 API Endpoints."""
def __init__(self, storage, control, validate, defaults): def __init__(self, storage, control, validate, defaults):
self._queue_controller = storage.queue_controller self._queue_controller = storage.queue_controller

22
zaqar/api/v2/request.py Normal file
View File

@ -0,0 +1,22 @@
# Copyright (c) 2013 Red Hat, Inc.
#
# 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.
from zaqar.api.v1_1 import request as v1_1
class RequestSchema(v1_1.RequestSchema):
headers = v1_1.RequestSchema.headers
schema = v1_1.RequestSchema.schema

410
zaqar/api/v2/response.py Normal file
View File

@ -0,0 +1,410 @@
# Copyright (c) 2013 Rackspace, Inc.
#
# 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.
from zaqar.common.api import api
class ResponseSchema(api.Api):
"""Define validation schema for json response."""
def __init__(self, limits):
self.limits = limits
age = {
"type": "number",
"minimum": 0
}
message = {
"type": "object",
"properties": {
"id": {
"type": "string",
},
"href": {
"type": "string",
"pattern": "^(/v1/queues/[a-zA-Z0-9_-]{1,64}"
"/messages/[a-zA-Z0-9_-]+)(\?claim_id=[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", "id"],
"additionalProperties": False,
}
claim_href = {
"type": "string",
"pattern": "^(/v2/queues/[a-zA-Z0-9_-]{1,64}"
"/messages/[a-zA-Z0-9_-]+)"
"\?claim_id=[a-zA-Z0-9_-]+$"
}
flavor = {
'type': 'object',
'properties': {
'href': {
'type': 'string',
'pattern': '^/v2/flavors/[a-zA-Z0-9_-]{1,64}$'
},
'pool': {
'type': 'string',
},
'project': {
'type': 'string'
},
'capabilities': {
'type': 'object',
'additionalProperties': True
}
},
'required': ['href', 'pool', 'project'],
'additionalProperties': False,
}
self.schema = {
'message_get_many': {
'type': 'object',
'properties': {
'messages': {
"type": "array",
"items": message,
"minItems": 1,
"maxItems": self.limits.max_messages_per_page
}
},
'required': ['messages'],
'additionalProperties': False,
},
'queue_list': {
'type': 'object',
'properties': {
'links': {
'type': 'array',
'items': {
'type': 'object',
'properties': {
'rel': {
'type': 'string',
'enum': ['next'],
},
'href': {
'type': 'string',
"pattern": "^/v2/queues\?",
}
},
'required': ['rel', 'href'],
'additionalProperties': False,
},
'minItems': 1,
'maxItems': 1,
},
'queues': {
'type': 'array',
'items': {
'type': 'object',
'properties': {
'name': {
'type': 'string',
'pattern': '^[a-zA-Z0-9_-]{1,64}$'
},
'href': {
'type': 'string',
'pattern': '^/v2/queues/'
'[a-zA-Z0-9_-]{1,64}$',
},
'metadata': {
'type': 'object',
}
},
'required': ['name', 'href'],
'additionalProperties': False,
},
'minItems': 1,
'maxItems': self.limits.max_queues_per_page,
}
},
'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
},
'pool_list': {
'type': 'object',
'properties': {
'links': {
'type': 'array',
'items': {
'type': 'object',
'properties': {
'rel': {
'type': 'string'
},
'href': {
'type': 'string',
'pattern': '^/v2/pools\?'
}
},
'required': ['rel', 'href'],
'additionalProperties': False
}
},
'pools': {
'type': 'array',
'items': {
'type': 'object',
'properties': {
'href': {
'type': 'string',
'pattern': '^/v2/'
'pools/[a-zA-Z0-9_-]{1,64}$'
},
'weight': {
'type': 'number',
'minimum': -1
},
'name': {
'type': 'string'
},
'uri': {
'type': 'string'
},
'group': {
'type': ['string', 'null']
},
'options': {
'type': 'object',
'additionalProperties': True
}
},
'required': ['href', 'weight', 'uri', 'group'],
'additionalProperties': False,
},
}
},
'required': ['links', 'pools'],
'additionalProperties': False
},
'message_list': {
'type': 'object',
'properties': {
'links': {
'type': 'array',
'items': {
'type': 'object',
'properties': {
'rel': {
'type': 'string'
},
'href': {
'type': 'string',
'pattern': '^/v2/queues/[a-zA-Z0-9_-]+'
'/messages\?(.)*$'
}
},
'required': ['rel', 'href'],
'additionalProperties': False
}
},
'messages': {
"type": "array",
"items": message,
"minItems": 0,
"maxItems": self.limits.max_messages_per_claim_or_pop
}
}
},
'pool_detail': {
'type': 'object',
'properties': {
'name': {
'type': 'string'
},
'uri': {
'type': 'string'
},
'group': {
'type': ['string', 'null']
},
'weight': {
'type': 'number',
'minimum': -1
},
'href': {
'type': 'string',
'pattern': '^/v2/pools/'
'[a-zA-Z0-9_\-]+$'
},
'options': {
'type': 'object',
'additionalProperties': True
}
},
'required': ['uri', 'weight', 'href'],
'additionalProperties': False
},
'claim_create': {
'type': 'object',
'properties': {
'messages': {
"type": "array",
"items": {
"type": "object",
"properties": {
"id": {
"type": "string",
},
"href": claim_href,
"ttl": {
"type": "number",
"minimum": 1,
"maximum": self.limits.max_message_ttl
},
"age": age,
"body": {
"type": "object"
}
},
"required": ["href", "ttl", "age", "body", "id"],
"additionalProperties": False,
},
"minItems": 1,
"maxItems": self.limits.max_messages_per_page
}
},
'required': ['messages'],
'additionalProperties': False
},
'claim_get': {
'type': 'object',
'properties': {
'age': age,
'ttl': {
'type': 'number',
'minimum': 0,
'maximum': self.limits.max_claim_ttl
},
'href': {
'type': 'string',
'pattern': '^/v2/queues/[a-zA-Z0-9_-]+'
'/claims/[a-zA-Z0-9_-]+$'
},
'messages': {
"type": "array",
"items": {
"type": "object",
"properties": {
"id": {
"type": "string",
},
"href": claim_href,
"ttl": {
"type": "number",
"minimum": 1,
"maximum": self.limits.max_message_ttl
},
"age": age,
"body": {
"type": "object"
}
},
"required": ["href", "ttl", "age", "body", "id"],
"additionalProperties": False,
},
"minItems": 1,
"maxItems": self.limits.max_messages_per_page
}
},
'required': ['age', 'ttl', 'messages', 'href'],
'additionalProperties': False
},
'flavor_list': {
'type': 'object',
'properties': {
'links': {
'type': 'array',
'items': {
'type': 'object',
'properties': {
'rel': {
'type': 'string'
},
'href': {
'type': 'string',
'pattern': '^/v2/flavors\?'
}
},
'required': ['rel', 'href'],
'additionalProperties': False
}
},
'flavors': {
'type': 'array',
'items': flavor,
}
},
'required': ['links', 'flavors'],
'additionalProperties': False
}
}

View File

@ -24,7 +24,7 @@ from zaqar.tests.unit.transport.websocket import base
from zaqar.tests.unit.transport.websocket import utils as test_utils from zaqar.tests.unit.transport.websocket import utils as test_utils
class AuthTest(base.V1_1Base): class AuthTest(base.V2Base):
config_file = "websocket_mongodb_keystone_auth.conf" config_file = "websocket_mongodb_keystone_auth.conf"

View File

@ -29,7 +29,7 @@ from zaqar.transport import validation
@ddt.ddt @ddt.ddt
class MessagesBaseTest(base.V1_1Base): class MessagesBaseTest(base.V2Base):
config_file = "websocket_mongodb.conf" config_file = "websocket_mongodb.conf"
@ -583,5 +583,5 @@ class MessagesBaseTest(base.V1_1Base):
self.assertIn('error', response['body']) self.assertIn('error', response['body'])
self.assertEqual({'status': 400}, response['headers']) self.assertEqual({'status': 400}, response['headers'])
self.assertEqual( self.assertEqual(
{'action': None, 'api': 'v1.1', 'body': {}, 'headers': {}}, {'action': None, 'api': 'v2', 'body': {}, 'headers': {}},
response['request']) response['request'])

View File

@ -24,7 +24,7 @@ from zaqar.tests.unit.transport.websocket import utils as test_utils
@ddt.ddt @ddt.ddt
class QueueLifecycleBaseTest(base.V1_1Base): class QueueLifecycleBaseTest(base.V2Base):
config_file = "websocket_mongodb.conf" config_file = "websocket_mongodb.conf"