246 lines
9.4 KiB
Python
246 lines
9.4 KiB
Python
# Copyright 2016 Andrew Kerr
|
|
# 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 ddt
|
|
from tempest import config
|
|
from tempest.lib.common.utils import data_utils
|
|
import testtools
|
|
from testtools import testcase as tc
|
|
|
|
from manila_tempest_tests.common import constants
|
|
from manila_tempest_tests.tests.api import base
|
|
|
|
CONF = config.CONF
|
|
|
|
|
|
@testtools.skipUnless(
|
|
CONF.share.run_share_group_tests, 'Share Group tests disabled.')
|
|
@base.skip_if_microversion_lt(constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
@ddt.ddt
|
|
class ShareGroupTypesTest(base.BaseSharesAdminTest):
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(ShareGroupTypesTest, cls).resource_setup()
|
|
|
|
# Create 2 share_types
|
|
name = data_utils.rand_name("tempest-manila")
|
|
extra_specs = cls.add_extra_specs_to_dict()
|
|
share_type = cls.create_share_type(name, extra_specs=extra_specs)
|
|
cls.share_type = share_type['share_type']
|
|
|
|
name = data_utils.rand_name("tempest-manila")
|
|
share_type = cls.create_share_type(name, extra_specs=extra_specs)
|
|
cls.share_type2 = share_type['share_type']
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@ddt.data('id', 'name')
|
|
def test_create_get_delete_share_group_type_min(self, st_key):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
|
|
# Create share group type
|
|
sg_type_c = self.create_share_group_type(
|
|
name=name,
|
|
share_types=self.share_type[st_key],
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertEqual(
|
|
[self.share_type['id']],
|
|
sg_type_c['share_types'],
|
|
'Share type not applied correctly.')
|
|
|
|
# Read share group type
|
|
sg_type_r = self.shares_v2_client.get_share_group_type(sg_type_c['id'])
|
|
keys = set(sg_type_r.keys())
|
|
self.assertTrue(
|
|
constants.SHARE_GROUP_TYPE_REQUIRED_KEYS.issubset(keys),
|
|
'At least one expected key missing from share group type '
|
|
'response. Expected %s, got %s.' % (
|
|
constants.SHARE_GROUP_TYPE_REQUIRED_KEYS, keys))
|
|
self.assertEqual(sg_type_c['name'], sg_type_r['name'])
|
|
|
|
# Delete share group type
|
|
self.shares_v2_client.delete_share_group_type(
|
|
sg_type_r['id'], version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
self.shares_v2_client.wait_for_resource_deletion(
|
|
share_group_type_id=sg_type_r['id'])
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@ddt.data('id', 'name')
|
|
def test_create_share_group_type_multiple_share_types_min(self, st_key):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
|
|
sg_type = self.create_share_group_type(
|
|
name=name,
|
|
share_types=[self.share_type[st_key], self.share_type2[st_key]],
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertEqual(
|
|
{self.share_type['id'], self.share_type2['id']},
|
|
set(sg_type['share_types']),
|
|
'Share types not applied correctly.')
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_create_share_group_type_with_one_spec_min(self):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
group_specs = {'key': 'value'}
|
|
|
|
sg_type = self.create_share_group_type(
|
|
name=name,
|
|
share_types=self.share_type['id'],
|
|
group_specs=group_specs,
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertDictMatch(group_specs, sg_type['group_specs'])
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_create_share_group_type_with_multiple_specs_min(self):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
group_specs = {'key1': 'value1', 'key2': 'value2'}
|
|
|
|
sg_type = self.create_share_group_type(
|
|
name=name,
|
|
share_types=self.share_type['id'],
|
|
group_specs=group_specs,
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertDictMatch(group_specs, sg_type['group_specs'])
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_single_share_group_type_spec_min(self):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
group_specs = {'key1': 'value1', 'key2': 'value2'}
|
|
|
|
sg_type = self.create_share_group_type(
|
|
name=name,
|
|
share_types=self.share_type['id'],
|
|
group_specs=group_specs,
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertDictMatch(group_specs, sg_type['group_specs'])
|
|
|
|
group_specs = {'key1': 'value1', 'key2': 'value2'}
|
|
|
|
self.shares_v2_client.update_share_group_type_spec(
|
|
sg_type['id'], 'key1', 'value3')
|
|
sg_type = self.shares_v2_client.get_share_group_type(sg_type['id'])
|
|
|
|
self.assertIn('key1', sg_type['group_specs'])
|
|
self.assertIn('key2', sg_type['group_specs'])
|
|
self.assertEqual('value3', sg_type['group_specs']['key1'])
|
|
self.assertEqual(group_specs['key2'], sg_type['group_specs']['key2'])
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_all_share_group_type_specs_min(self):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
group_specs = {'key1': 'value1', 'key2': 'value2'}
|
|
|
|
sg_type = self.create_share_group_type(
|
|
name=name,
|
|
share_types=self.share_type['id'],
|
|
group_specs=group_specs,
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertDictMatch(group_specs, sg_type['group_specs'])
|
|
|
|
group_specs = {'key1': 'value3', 'key2': 'value4'}
|
|
|
|
self.shares_v2_client.update_share_group_type_specs(
|
|
sg_type['id'], group_specs)
|
|
sg_type = self.shares_v2_client.get_share_group_type(sg_type['id'])
|
|
|
|
for k, v in group_specs.items():
|
|
self.assertIn(k, sg_type['group_specs'])
|
|
self.assertEqual(v, sg_type['group_specs'][k])
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_delete_single_share_group_type_spec_min(self):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
group_specs = {'key1': 'value1', 'key2': 'value2'}
|
|
|
|
sg_type = self.create_share_group_type(
|
|
name=name,
|
|
share_types=self.share_type['id'],
|
|
group_specs=group_specs,
|
|
cleanup_in_class=False,
|
|
version=constants.MIN_SHARE_GROUP_MICROVERSION)
|
|
|
|
self.assertDictMatch(group_specs, sg_type['group_specs'])
|
|
|
|
key_to_delete = 'key1'
|
|
group_specs.pop(key_to_delete)
|
|
|
|
self.shares_v2_client.delete_share_group_type_spec(
|
|
sg_type['id'], key_to_delete)
|
|
sg_type = self.shares_v2_client.get_share_group_type(
|
|
sg_type['id'])
|
|
|
|
self.assertDictMatch(group_specs, sg_type['group_specs'])
|
|
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_private_share_group_type_access(self):
|
|
name = data_utils.rand_name("tempest-manila")
|
|
group_specs = {"key1": "value1", "key2": "value2"}
|
|
project_id = self.shares_v2_client.tenant_id
|
|
|
|
# Create private share group type
|
|
sgt_create = self.create_share_group_type(
|
|
name=name,
|
|
share_types=[self.share_type['id']],
|
|
is_public=False,
|
|
group_specs=group_specs,
|
|
)
|
|
self.assertEqual(name, sgt_create['name'])
|
|
sgt_id = sgt_create["id"]
|
|
|
|
# It should not be listed without access
|
|
sgt_list = self.shares_v2_client.list_share_group_types()
|
|
self.assertFalse(any(sgt_id == sgt["id"] for sgt in sgt_list))
|
|
|
|
# List projects that have access for share group type - none expected
|
|
access = self.shares_v2_client.list_access_to_share_group_type(sgt_id)
|
|
self.assertEmpty(access)
|
|
|
|
# Add project access to share group type
|
|
access = self.shares_v2_client.add_access_to_share_group_type(
|
|
sgt_id, project_id)
|
|
|
|
# Now it should be listed
|
|
sgt_list = self.shares_v2_client.list_share_group_types()
|
|
self.assertTrue(any(sgt_id == sgt["id"] for sgt in sgt_list))
|
|
|
|
# List projects that have access for share group type - one expected
|
|
access = self.shares_v2_client.list_access_to_share_group_type(sgt_id)
|
|
expected = [{'share_group_type_id': sgt_id, 'project_id': project_id}]
|
|
self.assertEqual(expected, access)
|
|
|
|
# Remove project access from share group type
|
|
access = self.shares_v2_client.remove_access_from_share_group_type(
|
|
sgt_id, project_id)
|
|
|
|
# It should not be listed without access
|
|
sgt_list = self.shares_v2_client.list_share_group_types()
|
|
self.assertFalse(any(sgt_id == sgt["id"] for sgt in sgt_list))
|
|
|
|
# List projects that have access for share group type - none expected
|
|
access = self.shares_v2_client.list_access_to_share_group_type(sgt_id)
|
|
self.assertEmpty(access)
|