Cinder get-capabilities tests
Cinder allows getting capabilities for a storage back end Added: - Api for get-capabilities - Documentation reference for cinder show_pools Tests: - Test get capabilities for a given back end - Test get volume stats Note: Only admin has the privileges to perform get-capabilities action, by default. Change-Id: I1329a1339e1d8526f94ee57fb0ab43a78d881174
This commit is contained in:
parent
0a70535150
commit
b6baff8c07
79
tempest/api/volume/admin/test_backends_capabilities.py
Normal file
79
tempest/api/volume/admin/test_backends_capabilities.py
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
# Copyright 2016 OpenStack Foundation
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
import operator
|
||||||
|
|
||||||
|
from tempest.api.volume import base
|
||||||
|
from tempest import test
|
||||||
|
|
||||||
|
|
||||||
|
class BackendsCapabilitiesAdminV2TestsJSON(base.BaseVolumeAdminTest):
|
||||||
|
|
||||||
|
CAPABILITIES = ('namespace',
|
||||||
|
'vendor_name',
|
||||||
|
'volume_backend_name',
|
||||||
|
'pool_name',
|
||||||
|
'driver_version',
|
||||||
|
'storage_protocol',
|
||||||
|
'display_name',
|
||||||
|
'description',
|
||||||
|
'visibility',
|
||||||
|
'properties')
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resource_setup(cls):
|
||||||
|
super(BackendsCapabilitiesAdminV2TestsJSON, cls).resource_setup()
|
||||||
|
# Get host list, formation: host@backend-name
|
||||||
|
cls.hosts = [
|
||||||
|
pool['name'] for pool in
|
||||||
|
cls.admin_volume_client.show_pools()['pools']
|
||||||
|
]
|
||||||
|
|
||||||
|
@test.idempotent_id('3750af44-5ea2-4cd4-bc3e-56e7e6caf854')
|
||||||
|
def test_get_capabilities_backend(self):
|
||||||
|
# Test backend properties
|
||||||
|
backend = self.admin_volume_client.show_backend_capabilities(
|
||||||
|
self.hosts[0])
|
||||||
|
|
||||||
|
# Verify getting capabilities parameters from a backend
|
||||||
|
for key in self.CAPABILITIES:
|
||||||
|
self.assertIn(key, backend)
|
||||||
|
|
||||||
|
@test.idempotent_id('a9035743-d46a-47c5-9cb7-3c80ea16dea0')
|
||||||
|
def test_compare_volume_stats_values(self):
|
||||||
|
# Test values comparison between show_backend_capabilities
|
||||||
|
# to show_pools
|
||||||
|
VOLUME_STATS = ('vendor_name',
|
||||||
|
'volume_backend_name',
|
||||||
|
'storage_protocol')
|
||||||
|
|
||||||
|
# Get list backend capabilities using show_pools
|
||||||
|
cinder_pools = [
|
||||||
|
pool['capabilities'] for pool in
|
||||||
|
self.admin_volume_client.show_pools(detail=True)['pools']
|
||||||
|
]
|
||||||
|
|
||||||
|
# Get list backends capabilities using show_backend_capabilities
|
||||||
|
capabilities = [
|
||||||
|
self.admin_volume_client.show_backend_capabilities(
|
||||||
|
host=host) for host in self.hosts
|
||||||
|
]
|
||||||
|
|
||||||
|
# Returns a tuple of VOLUME_STATS values
|
||||||
|
expected_list = map(operator.itemgetter(*VOLUME_STATS),
|
||||||
|
cinder_pools)
|
||||||
|
observed_list = map(operator.itemgetter(*VOLUME_STATS),
|
||||||
|
capabilities)
|
||||||
|
self.assertEqual(expected_list, observed_list)
|
@ -63,7 +63,11 @@ class BaseVolumesClient(rest_client.RestClient):
|
|||||||
return rest_client.ResponseBody(resp, body)
|
return rest_client.ResponseBody(resp, body)
|
||||||
|
|
||||||
def show_pools(self, detail=False):
|
def show_pools(self, detail=False):
|
||||||
# List all the volumes pools (hosts)
|
"""List all the volumes pools (hosts).
|
||||||
|
|
||||||
|
Output params: see http://developer.openstack.org/
|
||||||
|
api-ref-blockstorage-v2.html#listPools
|
||||||
|
"""
|
||||||
url = 'scheduler-stats/get_pools'
|
url = 'scheduler-stats/get_pools'
|
||||||
if detail:
|
if detail:
|
||||||
url += '?detail=True'
|
url += '?detail=True'
|
||||||
@ -73,6 +77,19 @@ class BaseVolumesClient(rest_client.RestClient):
|
|||||||
self.expected_success(200, resp.status)
|
self.expected_success(200, resp.status)
|
||||||
return rest_client.ResponseBody(resp, body)
|
return rest_client.ResponseBody(resp, body)
|
||||||
|
|
||||||
|
def show_backend_capabilities(self, host):
|
||||||
|
"""Shows capabilities for a storage back end.
|
||||||
|
|
||||||
|
Output params: see http://developer.openstack.org/
|
||||||
|
api-ref-blockstorage-v2.html
|
||||||
|
#showBackendCapabilities
|
||||||
|
"""
|
||||||
|
url = 'capabilities/%s' % host
|
||||||
|
resp, body = self.get(url)
|
||||||
|
body = json.loads(body)
|
||||||
|
self.expected_success(200, resp.status)
|
||||||
|
return rest_client.ResponseBody(resp, body)
|
||||||
|
|
||||||
def show_volume(self, volume_id):
|
def show_volume(self, volume_id):
|
||||||
"""Returns the details of a single volume."""
|
"""Returns the details of a single volume."""
|
||||||
url = "volumes/%s" % str(volume_id)
|
url = "volumes/%s" % str(volume_id)
|
||||||
|
Loading…
Reference in New Issue
Block a user