Add 'params' argument to v2 list_backups API

This patch adds 'params' argument to list_backups API in v2 BackupsClient,
to enable passing additional information in the query string of the HTTP
request.

Change-Id: I8e31a55741f9bebf7b3d70491e2353b466dce06e
This commit is contained in:
jeremy.zhang 2017-07-07 15:55:06 +08:00
parent 21dd8a5ee2
commit a2df0f57a7
3 changed files with 134 additions and 2 deletions

View File

@ -0,0 +1,6 @@
---
features:
- |
The ``list_backups`` method of the v2 ``BackupsClient`` class now has
an additional ``**params`` argument that enables passing additional
information in the query string of the HTTP request.

View File

@ -14,6 +14,7 @@
# under the License.
from oslo_serialization import jsonutils as json
from six.moves.urllib import parse as urllib
from tempest.lib.common import rest_client
from tempest.lib import exceptions as lib_exc
@ -64,11 +65,19 @@ class BackupsClient(base_client.BaseClient):
self.expected_success(200, resp.status)
return rest_client.ResponseBody(resp, body)
def list_backups(self, detail=False):
"""Information for all the tenant's backups."""
def list_backups(self, detail=False, **params):
"""List all the tenant's backups.
For a full list of available parameters, please refer to the official
API reference:
http://developer.openstack.org/api-ref/block-storage/v2/#list-backups
http://developer.openstack.org/api-ref/block-storage/v2/#list-backups-with-details
"""
url = "backups"
if detail:
url += "/detail"
if params:
url += '?%s' % urllib.urlencode(params)
resp, body = self.get(url)
body = json.loads(body)
self.expected_success(200, resp.status)

View File

@ -0,0 +1,117 @@
# Copyright 2017 FiberHome Telecommunication Technologies CO.,LTD
# All Rights Reserved.
#
# 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 tempest.lib.services.volume.v2 import backups_client
from tempest.tests.lib import fake_auth_provider
from tempest.tests.lib.services import base
class TestBackupsClient(base.BaseServiceTest):
FAKE_BACKUP_LIST = {
"backups": [
{
"id": "2ef47aee-8844-490c-804d-2a8efe561c65",
"links": [
{
"href": "fake-url-1",
"rel": "self"
},
{
"href": "fake-url-2",
"rel": "bookmark"
}
],
"name": "backup001"
}
]
}
FAKE_BACKUP_LIST_WITH_DETAIL = {
"backups": [
{
"availability_zone": "az1",
"container": "volumebackups",
"created_at": "2013-04-02T10:35:27.000000",
"description": None,
"fail_reason": None,
"id": "2ef47aee-8844-490c-804d-2a8efe561c65",
"links": [
{
"href": "fake-url-1",
"rel": "self"
},
{
"href": "fake-url-2",
"rel": "bookmark"
}
],
"name": "backup001",
"object_count": 22,
"size": 1,
"status": "available",
"volume_id": "e5185058-943a-4cb4-96d9-72c184c337d6",
"is_incremental": True,
"has_dependent_backups": False
}
]
}
def setUp(self):
super(TestBackupsClient, self).setUp()
fake_auth = fake_auth_provider.FakeAuthProvider()
self.client = backups_client.BackupsClient(fake_auth,
'volume',
'regionOne')
def _test_list_backups(self, detail=False, mock_args='backups',
bytes_body=False, **params):
if detail:
resp_body = self.FAKE_BACKUP_LIST_WITH_DETAIL
else:
resp_body = self.FAKE_BACKUP_LIST
self.check_service_client_function(
self.client.list_backups,
'tempest.lib.common.rest_client.RestClient.get',
resp_body,
to_utf=bytes_body,
mock_args=[mock_args],
detail=detail,
**params)
def test_list_backups_with_str_body(self):
self._test_list_backups()
def test_list_backups_with_bytes_body(self):
self._test_list_backups(bytes_body=True)
def test_list_backups_with_detail_with_str_body(self):
mock_args = "backups/detail"
self._test_list_backups(detail=True, mock_args=mock_args)
def test_list_backups_with_detail_with_bytes_body(self):
mock_args = "backups/detail"
self._test_list_backups(detail=True, mock_args=mock_args,
bytes_body=True)
def test_list_backups_with_params(self):
# Run the test separately for each param, to avoid assertion error
# resulting from randomized params order.
mock_args = 'backups?sort_key=name'
self._test_list_backups(mock_args=mock_args, sort_key='name')
mock_args = 'backups/detail?limit=10'
self._test_list_backups(detail=True, mock_args=mock_args,
bytes_body=True, limit=10)