Ensure the float value of api version could work

Now if we pass a float value of api version such as "v1.0" or
"v2.0", client will raise a DriverLoadFailure error. Because
that client can't match a sutiable API entry.

So we should ensure that that some value like "v1.0" could
work as "v1".

Change-Id: I9631a083fd96a535153b6029b95a1d3c8d9966a2
Closes-bug: #1572616
This commit is contained in:
wangxiyuan 2016-04-21 12:15:24 +08:00
parent c18c30085b
commit eeba0f3b8c
3 changed files with 31 additions and 3 deletions

View File

@ -16,6 +16,8 @@
import json
from zaqarclient.queues.v1 import api as api_v1
from zaqarclient.queues.v2 import api as api_v2
from zaqarclient.tests import base
from zaqarclient.transport import request
@ -44,3 +46,25 @@ class TestRequest(base.TestBase):
req = request.prepare_request(auth_opts, data=data)
self.assertTrue(isinstance(req, request.Request))
self.assertEqual(json.dumps(data), req.content)
def test_request_with_right_version(self):
auth_opts = self.conf.get('auth_opts', {})
api_version = 1
req = request.prepare_request(auth_opts, api=api_version)
self.assertTrue(isinstance(req.api, api_v1.V1))
api_version = 1.0
req = request.prepare_request(auth_opts, api=api_version)
self.assertTrue(isinstance(req.api, api_v1.V1))
api_version = 1.1
req = request.prepare_request(auth_opts, api=api_version)
self.assertTrue(isinstance(req.api, api_v1.V1_1))
api_version = 2
req = request.prepare_request(auth_opts, api=api_version)
self.assertTrue(isinstance(req.api, api_v2.V2))
api_version = 2.0
req = request.prepare_request(auth_opts, api=api_version)
self.assertTrue(isinstance(req.api, api_v2.V2))

View File

@ -71,10 +71,9 @@ class Client(object):
return (trans or self.transport)
def _request_and_transport(self):
api = 'queues.v' + str(self.api_version)
req = request.prepare_request(self.auth_opts,
endpoint=self.api_url,
api=api)
api=self.api_version)
req.headers['Client-ID'] = self.client_uuid

View File

@ -93,7 +93,12 @@ class Request(object):
headers=None, api=None):
self._api = None
self._api_mod = api
# ensure that some values like "v1.0" could work as "v1"
self._api_mod = None
if api and int(api) == api:
self._api_mod = 'queues.v' + str(int(api))
elif api:
self._api_mod = 'queues.v' + str(api)
self.endpoint = endpoint
self.operation = operation