
This patch enables Cinder v1/v2 QoS API support, adding following subcommands to cinder client: * create QoS Specs cinder qos-create <name> <key=value> [<key=value> ...] * delete QoS Specs cinder qos-delete [--force <True|False>] <qos_specs> 'force' is a flag indicates whether to delete a 'in-use' qos specs, which is still associated with other entities (e.g. volume types). * update QoS Specs - add new key/value pairs or update existing key/value cinder qos-key <qos_specs_id> set key=value [key=value ...] - delete key/value pairs cinder qos-key <qos_specs id> unset key [key ...] * associate QoS Specs with specified volume type cinder qos-associate <qos_specs_id> <volume_type_id> * disassociate QoS Specs from specified volume type cinder qos-disassociate <qos_specs_id> <volume_type_id> * disassociate QoS Specs from all associated volume types cinder qos-disassociate-all <qos_specs> * query entities that are associated with specified QoS Specs cinder qos-get-associations <qos_specs_id> * list all QoS Specs cinder qos-list DocImpact Change-Id: Ie1ddd29fede8660b475bac14c4fc35496d5fe0bc
80 lines
2.9 KiB
Python
80 lines
2.9 KiB
Python
# Copyright (C) 2013 eBay Inc.
|
|
# 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 cinderclient.tests import utils
|
|
from cinderclient.tests.v1 import fakes
|
|
|
|
|
|
cs = fakes.FakeClient()
|
|
|
|
|
|
class QoSSpecsTest(utils.TestCase):
|
|
|
|
def test_create(self):
|
|
specs = dict(k1='v1', k2='v2')
|
|
cs.qos_specs.create('qos-name', specs)
|
|
cs.assert_called('POST', '/qos-specs')
|
|
|
|
def test_get(self):
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
cs.qos_specs.get(qos_id)
|
|
cs.assert_called('GET', '/qos-specs/%s' % qos_id)
|
|
|
|
def test_list(self):
|
|
cs.qos_specs.list()
|
|
cs.assert_called('GET', '/qos-specs')
|
|
|
|
def test_delete(self):
|
|
cs.qos_specs.delete('1B6B6A04-A927-4AEB-810B-B7BAAD49F57C')
|
|
cs.assert_called('DELETE',
|
|
'/qos-specs/1B6B6A04-A927-4AEB-810B-B7BAAD49F57C?'
|
|
'force=False')
|
|
|
|
def test_set_keys(self):
|
|
body = {'qos_specs': dict(k1='v1')}
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
cs.qos_specs.set_keys(qos_id, body)
|
|
cs.assert_called('PUT', '/qos-specs/%s' % qos_id)
|
|
|
|
def test_unset_keys(self):
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
body = {'keys': ['k1']}
|
|
cs.qos_specs.unset_keys(qos_id, body)
|
|
cs.assert_called('PUT', '/qos-specs/%s/delete_keys' % qos_id)
|
|
|
|
def test_get_associations(self):
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
cs.qos_specs.get_associations(qos_id)
|
|
cs.assert_called('GET', '/qos-specs/%s/associations' % qos_id)
|
|
|
|
def test_associate(self):
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
type_id = '4230B13A-7A37-4E84-B777-EFBA6FCEE4FF'
|
|
cs.qos_specs.associate(qos_id, type_id)
|
|
cs.assert_called('GET', '/qos-specs/%s/associate?vol_type_id=%s'
|
|
% (qos_id, type_id))
|
|
|
|
def test_disassociate(self):
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
type_id = '4230B13A-7A37-4E84-B777-EFBA6FCEE4FF'
|
|
cs.qos_specs.disassociate(qos_id, type_id)
|
|
cs.assert_called('GET', '/qos-specs/%s/disassociate?vol_type_id=%s'
|
|
% (qos_id, type_id))
|
|
|
|
def test_disassociate_all(self):
|
|
qos_id = '1B6B6A04-A927-4AEB-810B-B7BAAD49F57C'
|
|
cs.qos_specs.disassociate_all(qos_id)
|
|
cs.assert_called('GET', '/qos-specs/%s/disassociate_all' % qos_id)
|