996 lines
41 KiB
Python
996 lines
41 KiB
Python
# Copyright 2014 Mirantis 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.
|
|
|
|
import ddt
|
|
from tempest import config
|
|
from tempest.lib.common.utils import data_utils
|
|
from tempest.lib import decorators
|
|
from tempest.lib import exceptions as lib_exc
|
|
import testtools
|
|
from testtools import testcase as tc
|
|
|
|
from manila_tempest_tests.tests.api import base
|
|
from manila_tempest_tests import utils
|
|
|
|
CONF = config.CONF
|
|
PRE_SHARE_GROUPS_MICROVERSION = "2.39"
|
|
SHARE_GROUPS_MICROVERSION = "2.40"
|
|
PRE_SHARE_REPLICA_QUOTAS_MICROVERSION = "2.52"
|
|
SHARE_REPLICA_QUOTAS_MICROVERSION = "2.53"
|
|
|
|
|
|
@ddt.ddt
|
|
class SharesAdminQuotasTest(base.BaseSharesAdminTest):
|
|
|
|
@classmethod
|
|
def skip_checks(cls):
|
|
super(SharesAdminQuotasTest, cls).skip_checks()
|
|
if not CONF.share.run_quota_tests:
|
|
msg = "Quota tests are disabled."
|
|
raise cls.skipException(msg)
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(SharesAdminQuotasTest, cls).resource_setup()
|
|
cls.client = cls.shares_v2_client
|
|
cls.user_id = cls.client.user_id
|
|
cls.tenant_id = cls.client.tenant_id
|
|
# create share type
|
|
cls.share_type = cls.create_share_type()
|
|
cls.share_type_id = cls.share_type['id']
|
|
|
|
@decorators.idempotent_id('f62c48e3-9736-4f0c-9f9b-f139f393ac0a')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_default_quotas(self):
|
|
quotas = self.client.default_quotas(self.tenant_id)['quota_set']
|
|
self.assertGreater(int(quotas["gigabytes"]), -2)
|
|
self.assertGreater(int(quotas["snapshot_gigabytes"]), -2)
|
|
self.assertGreater(int(quotas["shares"]), -2)
|
|
self.assertGreater(int(quotas["snapshots"]), -2)
|
|
self.assertGreater(int(quotas["share_networks"]), -2)
|
|
if utils.is_microversion_supported(SHARE_GROUPS_MICROVERSION):
|
|
self.assertGreater(int(quotas["share_groups"]), -2)
|
|
self.assertGreater(int(quotas["share_group_snapshots"]), -2)
|
|
if utils.share_replica_quotas_are_supported():
|
|
self.assertGreater(int(quotas["share_replicas"]), -2)
|
|
self.assertGreater(int(quotas["replica_gigabytes"]), -2)
|
|
|
|
@decorators.idempotent_id('1ff57cfa-cd8d-495f-86eb-9fead307428e')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_show_quotas(self):
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
self.assertGreater(int(quotas["gigabytes"]), -2)
|
|
self.assertGreater(int(quotas["snapshot_gigabytes"]), -2)
|
|
self.assertGreater(int(quotas["shares"]), -2)
|
|
self.assertGreater(int(quotas["snapshots"]), -2)
|
|
self.assertGreater(int(quotas["share_networks"]), -2)
|
|
if utils.is_microversion_supported(SHARE_GROUPS_MICROVERSION):
|
|
self.assertGreater(int(quotas["share_groups"]), -2)
|
|
self.assertGreater(int(quotas["share_group_snapshots"]), -2)
|
|
if utils.share_replica_quotas_are_supported():
|
|
self.assertGreater(int(quotas["share_replicas"]), -2)
|
|
self.assertGreater(int(quotas["replica_gigabytes"]), -2)
|
|
|
|
@decorators.idempotent_id('9b96dd45-7c0d-41ee-88e4-600185f61358')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_show_quotas_for_user(self):
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
self.assertGreater(int(quotas["gigabytes"]), -2)
|
|
self.assertGreater(int(quotas["snapshot_gigabytes"]), -2)
|
|
self.assertGreater(int(quotas["shares"]), -2)
|
|
self.assertGreater(int(quotas["snapshots"]), -2)
|
|
self.assertGreater(int(quotas["share_networks"]), -2)
|
|
if utils.is_microversion_supported(SHARE_GROUPS_MICROVERSION):
|
|
self.assertGreater(int(quotas["share_groups"]), -2)
|
|
self.assertGreater(int(quotas["share_group_snapshots"]), -2)
|
|
if utils.share_replica_quotas_are_supported():
|
|
self.assertGreater(int(quotas["share_replicas"]), -2)
|
|
self.assertGreater(int(quotas["replica_gigabytes"]), -2)
|
|
|
|
@decorators.idempotent_id('2e98a13e-b2ed-4977-bafe-47ea48b504f2')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported(PRE_SHARE_GROUPS_MICROVERSION)
|
|
def test_show_sg_quotas_using_too_old_microversion(self):
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, version=PRE_SHARE_GROUPS_MICROVERSION)['quota_set']
|
|
|
|
for key in ('share_groups', 'share_group_snapshots'):
|
|
self.assertNotIn(key, quotas)
|
|
|
|
@decorators.idempotent_id('b8bcbc04-68fb-4c8f-9f4c-a3b6c6b8911c')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported(PRE_SHARE_GROUPS_MICROVERSION)
|
|
def test_show_sg_quotas_for_user_using_too_old_microversion(self):
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id,
|
|
version=PRE_SHARE_GROUPS_MICROVERSION)['quota_set']
|
|
|
|
for key in ('share_groups', 'share_group_snapshots'):
|
|
self.assertNotIn(key, quotas)
|
|
|
|
@decorators.idempotent_id('19fe431b-e83e-4c4e-acb8-018d7a470c8b')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported(
|
|
PRE_SHARE_REPLICA_QUOTAS_MICROVERSION)
|
|
def test_show_replica_quotas_for_user_using_too_old_microversion(self):
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id,
|
|
version=PRE_SHARE_REPLICA_QUOTAS_MICROVERSION)['quota_set']
|
|
|
|
for key in ('share_replicas', 'replica_gigabytes'):
|
|
self.assertNotIn(key, quotas)
|
|
|
|
@ddt.data(
|
|
('id', True),
|
|
('name', False),
|
|
)
|
|
@ddt.unpack
|
|
@decorators.idempotent_id('836e1725-2853-4d54-b281-8173773d8527')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported("2.39")
|
|
def test_show_share_type_quotas(self, share_type_key, is_st_public):
|
|
# Check if the used microversion supports 'share_replica' and
|
|
# 'replica_gigabytes' quotas
|
|
replica_quotas_supported = utils.share_replica_quotas_are_supported()
|
|
|
|
# Create share type
|
|
share_type = self.create_share_type(
|
|
data_utils.rand_name("tempest-manila"),
|
|
is_public=is_st_public,
|
|
cleanup_in_class=False,
|
|
extra_specs=self.add_extra_specs_to_dict(),
|
|
)
|
|
if 'share_type' in share_type:
|
|
share_type = share_type['share_type']
|
|
|
|
keys = ['shares', 'gigabytes', 'snapshots', 'snapshot_gigabytes']
|
|
|
|
if replica_quotas_supported:
|
|
keys.append('share_replicas')
|
|
keys.append('replica_gigabytes')
|
|
|
|
# Get current project quotas
|
|
p_quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
# Get current share type quotas
|
|
st_quotas = self.client.show_quotas(
|
|
self.tenant_id, share_type=share_type[share_type_key])['quota_set']
|
|
|
|
# Share type quotas have values equal to project's
|
|
for key in keys:
|
|
self.assertEqual(st_quotas[key], p_quotas[key])
|
|
|
|
# Verify that we do not have share groups related quotas
|
|
# for share types.
|
|
for key in ('share_groups', 'share_group_snapshots'):
|
|
self.assertNotIn(key, st_quotas)
|
|
|
|
|
|
@ddt.ddt
|
|
class SharesAdminQuotasUpdateTest(base.BaseSharesAdminTest):
|
|
|
|
# We want to force a fresh project for this test class, since we'll be
|
|
# manipulating project quotas - and any pre-existing projects may have
|
|
# resources, quotas and the like that might interfere with our test cases.
|
|
force_tenant_isolation = True
|
|
|
|
@classmethod
|
|
def skip_checks(cls):
|
|
super(SharesAdminQuotasUpdateTest, cls).skip_checks()
|
|
if not CONF.auth.use_dynamic_credentials:
|
|
raise cls.skipException('Dynamic credentials are required')
|
|
if not CONF.share.run_quota_tests:
|
|
msg = "Quota tests are disabled."
|
|
raise cls.skipException(msg)
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(SharesAdminQuotasUpdateTest, cls).resource_setup()
|
|
# create share type
|
|
extra_specs = {}
|
|
if (CONF.share_feature_enabled.snapshot or
|
|
CONF.share.capability_snapshot_support):
|
|
extra_specs.update({'snapshot_support': True})
|
|
if (CONF.share_feature_enabled.share_from_snapshot or
|
|
CONF.share.capability_create_share_from_snapshot_support):
|
|
extra_specs.update({'create_share_from_snapshot_support': True})
|
|
cls.share_type = cls.create_share_type(extra_specs=extra_specs)
|
|
cls.share_type_id = cls.share_type['id']
|
|
# create share group type
|
|
cls.share_group_type = cls._create_share_group_type()
|
|
cls.share_group_type_id = cls.share_group_type['id']
|
|
cls.client = cls.shares_v2_client
|
|
cls.tenant_id = cls.client.tenant_id
|
|
cls.user_id = cls.client.user_id
|
|
|
|
@decorators.idempotent_id('da16e906-e8e6-4aa0-9fc1-76ed48cfd428')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_tenant_quota_shares(self):
|
|
# get current quotas
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
new_quota = int(quotas["shares"]) + 2
|
|
|
|
# set new quota for shares
|
|
updated = self.update_quotas(self.tenant_id, shares=new_quota)
|
|
|
|
self.assertEqual(new_quota, int(updated["shares"]))
|
|
|
|
@ddt.data(
|
|
"share_groups",
|
|
"share_group_snapshots",
|
|
)
|
|
@decorators.idempotent_id('cb09de7e-94e9-401a-b82b-8b2de210f8b9')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@testtools.skipUnless(
|
|
CONF.share.run_share_group_tests, 'Share Group tests disabled.')
|
|
@utils.skip_if_microversion_not_supported(SHARE_GROUPS_MICROVERSION)
|
|
def test_update_tenant_quota_share_groups(self, quota_key):
|
|
# Get current quotas
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
new_quota = int(quotas[quota_key]) + 2
|
|
|
|
# Set new quota
|
|
updated = self.update_quotas(self.tenant_id, **{quota_key: new_quota})
|
|
|
|
self.assertEqual(new_quota, int(updated[quota_key]))
|
|
|
|
@decorators.idempotent_id('2c7f9e19-268d-4420-a046-a7faf21174a1')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_user_quota_shares(self):
|
|
# get current quotas
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
new_quota = int(quotas["shares"]) - 1
|
|
|
|
# set new quota for shares
|
|
updated = self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
shares=new_quota)
|
|
|
|
self.assertEqual(new_quota, int(updated["shares"]))
|
|
|
|
@ddt.data(
|
|
"share_groups",
|
|
"share_group_snapshots",
|
|
)
|
|
@decorators.idempotent_id('c32a716b-f971-4855-97ea-f30d4423d03d')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@testtools.skipUnless(
|
|
CONF.share.run_share_group_tests, 'Share Group tests disabled.')
|
|
@utils.skip_if_microversion_not_supported(SHARE_GROUPS_MICROVERSION)
|
|
def test_update_user_quota_share_groups(self, quota_key):
|
|
# Get current quotas
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
new_quota = int(quotas[quota_key]) - 1
|
|
|
|
# Set new quota
|
|
updated = self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
**{quota_key: new_quota})
|
|
|
|
self.assertEqual(new_quota, int(updated[quota_key]))
|
|
|
|
@ddt.data(("share_replicas", False),
|
|
("share_replicas", True),
|
|
("replica_gigabytes", False),
|
|
("replica_gigabytes", True),
|
|
)
|
|
@ddt.unpack
|
|
@decorators.idempotent_id('af16dc89-c93d-43de-8902-2c88c75f107f')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported(
|
|
SHARE_REPLICA_QUOTAS_MICROVERSION)
|
|
def test_update_user_quota_replica_related(self, quota_key, use_user_id):
|
|
kwargs = {}
|
|
|
|
# Update the kwargs with user_id in case the user_id need to be
|
|
# specified in the request
|
|
kwargs.update({'user_id': self.user_id}) if use_user_id else None
|
|
quotas = self.client.show_quotas(self.tenant_id, **kwargs)['quota_set']
|
|
new_quota = int(quotas[quota_key]) - 1
|
|
|
|
# Add the updated quota into the kwargs
|
|
kwargs.update({quota_key: new_quota})
|
|
|
|
# Set the new quota based on tenant or tenant and user_id
|
|
updated = self.update_quotas(self.tenant_id, **kwargs)
|
|
|
|
self.assertEqual(new_quota, int(updated[quota_key]))
|
|
|
|
@ddt.data(
|
|
('id', True),
|
|
('name', False),
|
|
)
|
|
@ddt.unpack
|
|
@decorators.idempotent_id('155ea3de-b3b5-4aa0-be8b-eebcc19ce874')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported("2.39")
|
|
def test_update_share_type_quota(self, share_type_key, is_st_public):
|
|
# Check if the used microversion supports 'share_replica' and
|
|
# 'replica_gigabytes' quotas
|
|
replica_quotas_supported = utils.share_replica_quotas_are_supported()
|
|
share_type = self.create_share_type(is_public=is_st_public)
|
|
|
|
# Get current quotas
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, share_type=share_type[share_type_key])['quota_set']
|
|
quota_keys = ['shares', 'gigabytes', 'snapshots', 'snapshot_gigabytes']
|
|
|
|
if replica_quotas_supported:
|
|
quota_keys.append('share_replicas')
|
|
quota_keys.append('replica_gigabytes')
|
|
|
|
# Update quotas
|
|
for q in quota_keys:
|
|
new_quota = int(quotas[q]) - 1
|
|
|
|
# Set new quota, cleanup isn't necessary, share type will be
|
|
# deleted when the test concludes, and that'll take care of
|
|
# share type quotas
|
|
updated = self.update_quotas(self.tenant_id,
|
|
share_type=share_type[share_type_key],
|
|
cleanup=False,
|
|
**{q: new_quota})
|
|
|
|
self.assertEqual(new_quota, int(updated[q]))
|
|
|
|
current_quotas = self.client.show_quotas(
|
|
self.tenant_id, share_type=share_type[share_type_key])['quota_set']
|
|
|
|
for q in quota_keys:
|
|
self.assertEqual(int(quotas[q]) - 1, current_quotas[q])
|
|
|
|
@decorators.idempotent_id('78957d97-afad-4371-a21e-79641fff83f6')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_tenant_quota_snapshots(self):
|
|
# get current quotas
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
new_quota = int(quotas["snapshots"]) + 2
|
|
|
|
# set new quota for snapshots
|
|
updated = self.update_quotas(self.tenant_id, snapshots=new_quota)
|
|
|
|
self.assertEqual(new_quota, int(updated["snapshots"]))
|
|
|
|
@decorators.idempotent_id('53f4fd79-39aa-42be-82ce-e423ebffe837')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_user_quota_snapshots(self):
|
|
# get current quotas
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
new_quota = int(quotas["snapshots"]) - 1
|
|
|
|
# set new quota for snapshots
|
|
updated = self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
snapshots=new_quota)
|
|
|
|
self.assertEqual(new_quota, int(updated["snapshots"]))
|
|
|
|
@decorators.idempotent_id('37ee5bd2-db07-4817-b71a-7c3e78634399')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_tenant_quota_gigabytes(self):
|
|
# get current quotas
|
|
custom = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
# make quotas for update
|
|
gigabytes = int(custom["gigabytes"]) + 2
|
|
|
|
# set new quota for shares
|
|
updated = self.update_quotas(self.tenant_id, gigabytes=gigabytes)
|
|
|
|
self.assertEqual(gigabytes, int(updated["gigabytes"]))
|
|
|
|
@decorators.idempotent_id('284a2e95-48a1-4f1b-b952-f734b1b6238a')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_tenant_quota_snapshot_gigabytes(self):
|
|
# get current quotas
|
|
custom = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
# make quotas for update
|
|
snapshot_gigabytes = int(custom["snapshot_gigabytes"]) + 2
|
|
|
|
# set new quota for shares
|
|
updated = self.update_quotas(self.tenant_id,
|
|
snapshot_gigabytes=snapshot_gigabytes)
|
|
|
|
self.assertEqual(snapshot_gigabytes,
|
|
int(updated["snapshot_gigabytes"]))
|
|
|
|
@decorators.idempotent_id('75977d53-f06b-41a2-8365-0ce549e4a51a')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_user_quota_gigabytes(self):
|
|
# get current quotas
|
|
custom = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
# make quotas for update
|
|
gigabytes = int(custom["gigabytes"]) - 1
|
|
|
|
# set new quota for shares
|
|
updated = self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
gigabytes=gigabytes)
|
|
|
|
self.assertEqual(gigabytes, int(updated["gigabytes"]))
|
|
|
|
@decorators.idempotent_id('00a189fc-93ed-44c2-b9dc-1d9b6c26d005')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_user_quota_snapshot_gigabytes(self):
|
|
# get current quotas
|
|
custom = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
# make quotas for update
|
|
snapshot_gigabytes = int(custom["snapshot_gigabytes"]) - 1
|
|
|
|
# set new quota for shares
|
|
updated = self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
snapshot_gigabytes=snapshot_gigabytes)
|
|
|
|
self.assertEqual(snapshot_gigabytes,
|
|
int(updated["snapshot_gigabytes"]))
|
|
|
|
@decorators.idempotent_id('da7f3179-f2f3-402e-82c2-e6855774a99a')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_tenant_quota_share_networks(self):
|
|
# get current quotas
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
new_quota = int(quotas["share_networks"]) + 2
|
|
|
|
# set new quota for share-networks
|
|
updated = self.update_quotas(self.tenant_id, share_networks=new_quota)
|
|
|
|
self.assertEqual(new_quota, int(updated["share_networks"]))
|
|
|
|
@decorators.idempotent_id('f75f01a0-5921-44ab-b373-bb9e070f87eb')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_user_quota_share_networks(self):
|
|
# get current quotas
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
new_quota = int(quotas["share_networks"]) - 1
|
|
|
|
# set new quota for share-networks
|
|
updated = self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
share_networks=new_quota)
|
|
|
|
self.assertEqual(new_quota, int(updated["share_networks"]))
|
|
|
|
@decorators.idempotent_id('84e24c32-ee78-461e-ac1f-f9e4d99f88e2')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_reset_tenant_quotas(self):
|
|
# Get default_quotas
|
|
default = self.client.default_quotas(self.tenant_id)['quota_set']
|
|
|
|
# Get current quotas
|
|
custom = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
# Make quotas for update
|
|
data = {
|
|
"shares": int(custom["shares"]) + 2,
|
|
"snapshots": int(custom["snapshots"]) + 2,
|
|
"gigabytes": int(custom["gigabytes"]) + 2,
|
|
"snapshot_gigabytes": int(custom["snapshot_gigabytes"]) + 2,
|
|
"share_networks": int(custom["share_networks"]) + 2,
|
|
}
|
|
if (utils.is_microversion_supported(SHARE_GROUPS_MICROVERSION) and
|
|
CONF.share.run_share_group_tests):
|
|
data["share_groups"] = int(custom["share_groups"]) + 2
|
|
data["share_group_snapshots"] = (
|
|
int(custom["share_group_snapshots"]) + 2)
|
|
if utils.share_replica_quotas_are_supported():
|
|
data["share_replicas"] = int(custom["share_replicas"]) + 2
|
|
data["replica_gigabytes"] = int(custom["replica_gigabytes"]) + 2
|
|
|
|
# set new quota, turn off cleanup - we'll do it right below
|
|
updated = self.update_quotas(self.tenant_id, cleanup=False, **data)
|
|
self.assertEqual(data["shares"], int(updated["shares"]))
|
|
self.assertEqual(data["snapshots"], int(updated["snapshots"]))
|
|
self.assertEqual(data["gigabytes"], int(updated["gigabytes"]))
|
|
self.assertEqual(
|
|
data["snapshot_gigabytes"], int(updated["snapshot_gigabytes"]))
|
|
self.assertEqual(
|
|
data["share_networks"], int(updated["share_networks"]))
|
|
if (utils.is_microversion_supported(SHARE_GROUPS_MICROVERSION) and
|
|
CONF.share.run_share_group_tests):
|
|
self.assertEqual(
|
|
data["share_groups"], int(updated["share_groups"]))
|
|
self.assertEqual(
|
|
data["share_group_snapshots"],
|
|
int(updated["share_group_snapshots"]))
|
|
if utils.share_replica_quotas_are_supported():
|
|
self.assertEqual(
|
|
data["share_replicas"], int(updated["share_replicas"]))
|
|
self.assertEqual(
|
|
data["replica_gigabytes"], int(updated["replica_gigabytes"]))
|
|
|
|
# Reset customized quotas
|
|
self.client.reset_quotas(self.tenant_id)
|
|
|
|
# Verify quotas
|
|
reseted = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
self.assertEqual(int(default["shares"]), int(reseted["shares"]))
|
|
self.assertEqual(int(default["snapshots"]), int(reseted["snapshots"]))
|
|
self.assertEqual(int(default["gigabytes"]), int(reseted["gigabytes"]))
|
|
self.assertEqual(
|
|
int(default["snapshot_gigabytes"]),
|
|
int(reseted["snapshot_gigabytes"]))
|
|
self.assertEqual(
|
|
int(default["share_networks"]), int(reseted["share_networks"]))
|
|
if (utils.is_microversion_supported(SHARE_GROUPS_MICROVERSION) and
|
|
CONF.share.run_share_group_tests):
|
|
self.assertEqual(
|
|
int(default["share_groups"]), int(reseted["share_groups"]))
|
|
self.assertEqual(
|
|
int(default["share_group_snapshots"]),
|
|
int(reseted["share_group_snapshots"]))
|
|
if utils.share_replica_quotas_are_supported():
|
|
self.assertEqual(
|
|
int(default["share_replicas"]), int(reseted["share_replicas"]))
|
|
self.assertEqual(
|
|
int(default["replica_gigabytes"]),
|
|
int(reseted["replica_gigabytes"]))
|
|
|
|
def _get_new_replica_quota_values(self, default_quotas, value_to_set):
|
|
new_values = {
|
|
'share_replicas': int(
|
|
default_quotas['share_replicas']) + value_to_set,
|
|
'replica_gigabytes': int(
|
|
default_quotas['replica_gigabytes']) + value_to_set
|
|
}
|
|
return new_values
|
|
|
|
@ddt.data(
|
|
('id', True),
|
|
('name', False),
|
|
)
|
|
@ddt.unpack
|
|
@decorators.idempotent_id('15e57302-5a14-4be4-8720-95b639c2bfad')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported("2.39")
|
|
def test_reset_share_type_quotas(self, share_type_key, is_st_public):
|
|
share_type = self.create_share_type(is_public=is_st_public)
|
|
quota_keys = ['shares', 'snapshots', 'gigabytes', 'snapshot_gigabytes']
|
|
|
|
# get default_quotas
|
|
default_quotas = self.client.default_quotas(
|
|
self.tenant_id)['quota_set']
|
|
|
|
kwargs = {}
|
|
|
|
# check if the replica_gigabytes and share_replicas quotas are
|
|
# supported
|
|
if utils.share_replica_quotas_are_supported():
|
|
kwargs.update(self._get_new_replica_quota_values(
|
|
default_quotas, 5))
|
|
quota_keys.append('share_replicas')
|
|
quota_keys.append('replica_gigabytes')
|
|
|
|
# set new project quota
|
|
updated_p_quota = self.update_quotas(
|
|
self.tenant_id,
|
|
shares=int(default_quotas['shares']) + 5,
|
|
snapshots=int(default_quotas['snapshots']) + 5,
|
|
gigabytes=int(default_quotas['gigabytes']) + 5,
|
|
snapshot_gigabytes=int(default_quotas['snapshot_gigabytes']) + 5,
|
|
**kwargs
|
|
)
|
|
|
|
if utils.share_replica_quotas_are_supported():
|
|
kwargs.update(self._get_new_replica_quota_values(
|
|
default_quotas, 3))
|
|
|
|
# set share type quota for project, don't cleanup, we'll do that below
|
|
self.update_quotas(
|
|
self.tenant_id,
|
|
share_type=share_type[share_type_key],
|
|
shares=int(default_quotas['shares']) + 3,
|
|
snapshots=int(default_quotas['snapshots']) + 3,
|
|
gigabytes=int(default_quotas['gigabytes']) + 3,
|
|
snapshot_gigabytes=int(default_quotas['snapshot_gigabytes']) + 3,
|
|
cleanup=False,
|
|
**kwargs
|
|
)
|
|
|
|
# reset share type quotas
|
|
self.client.reset_quotas(
|
|
self.tenant_id, share_type=share_type[share_type_key])
|
|
|
|
# verify quotas
|
|
current_p_quota = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
current_st_quota = self.client.show_quotas(
|
|
self.tenant_id, share_type=share_type[share_type_key])['quota_set']
|
|
for key in quota_keys:
|
|
self.assertEqual(updated_p_quota[key], current_p_quota[key])
|
|
|
|
# Default share type quotas are current project quotas
|
|
self.assertNotEqual(default_quotas[key], current_st_quota[key])
|
|
self.assertEqual(current_p_quota[key], current_st_quota[key])
|
|
|
|
@decorators.idempotent_id('d4bba375-7111-4b93-b6dd-4f0532febc3e')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_quota_for_shares(self):
|
|
self.update_quotas(self.tenant_id, shares=-1)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('shares'))
|
|
|
|
@decorators.idempotent_id('756ffd0e-a476-49af-ac85-9bb4ce5e29b7')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_user_quota_for_shares(self):
|
|
self.update_quotas(self.tenant_id, user_id=self.user_id, shares=-1)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('shares'))
|
|
|
|
@decorators.idempotent_id('9779d166-09d3-4745-8acc-2243eadec3ea')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_quota_for_snapshots(self):
|
|
self.update_quotas(self.tenant_id, snapshots=-1)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('snapshots'))
|
|
|
|
@decorators.idempotent_id('245b3bf3-09ef-4b6d-8643-f156bf1bf23c')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_user_quota_for_snapshots(self):
|
|
self.update_quotas(self.tenant_id, user_id=self.user_id, snapshots=-1)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('snapshots'))
|
|
|
|
@decorators.idempotent_id('b6a94e87-091a-48dc-9b51-13d81541869c')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_quota_for_gigabytes(self):
|
|
self.update_quotas(self.tenant_id, gigabytes=-1)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('gigabytes'))
|
|
|
|
@decorators.idempotent_id('0d044db4-ae5b-416d-aa51-098afb72cd6c')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_quota_for_snapshot_gigabytes(self):
|
|
self.update_quotas(self.tenant_id, snapshot_gigabytes=-1)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('snapshot_gigabytes'))
|
|
|
|
@decorators.idempotent_id('2de4b7cf-9189-413f-858b-860ecf5fd18b')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_user_quota_for_gigabytes(self):
|
|
self.update_quotas(self.tenant_id, user_id=self.user_id, gigabytes=-1)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('gigabytes'))
|
|
|
|
@decorators.idempotent_id('cbe63027-1108-4779-9fd3-22f41f60d6bb')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_user_quota_for_snapshot_gigabytes(self):
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
snapshot_gigabytes=-1)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('snapshot_gigabytes'))
|
|
|
|
@decorators.idempotent_id('e35455f5-92db-4669-ac21-9daf170df248')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_quota_for_share_networks(self):
|
|
self.update_quotas(self.tenant_id, share_networks=-1)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('share_networks'))
|
|
|
|
@decorators.idempotent_id('66b04887-e611-4d4f-a40b-c8b14766b6af')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_unlimited_user_quota_for_share_networks(self):
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
share_networks=-1)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('share_networks'))
|
|
|
|
@decorators.idempotent_id('7c2cd2d4-4352-4811-9e39-70f56e6297c2')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@testtools.skipUnless(
|
|
CONF.share.run_share_group_tests, 'Share Group tests disabled.')
|
|
@utils.skip_if_microversion_not_supported(SHARE_GROUPS_MICROVERSION)
|
|
def test_unlimited_quota_for_share_groups(self):
|
|
self.update_quotas(self.tenant_id, share_groups=-1)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('share_groups'))
|
|
|
|
@decorators.idempotent_id('76d270d5-f314-47cb-9c3f-409f8ff12ce2')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@testtools.skipUnless(
|
|
CONF.share.run_share_group_tests, 'Share Group tests disabled.')
|
|
@utils.skip_if_microversion_not_supported(SHARE_GROUPS_MICROVERSION)
|
|
def test_unlimited_user_quota_for_share_group_snapshots(self):
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
share_group_snapshots=-1)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get('share_group_snapshots'))
|
|
|
|
@ddt.data("share_replicas", "replica_gigabytes")
|
|
@decorators.idempotent_id('15aa5df5-b2ae-4a3a-acb8-efbbc84581be')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported(
|
|
SHARE_REPLICA_QUOTAS_MICROVERSION)
|
|
def test_unlimited_quota_for_replica_quotas(self, quota_key):
|
|
kwargs = {quota_key: -1}
|
|
self.update_quotas(self.tenant_id, **kwargs)
|
|
|
|
quotas = self.client.show_quotas(self.tenant_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get(quota_key))
|
|
|
|
@ddt.data("share_replicas", "replica_gigabytes")
|
|
@decorators.idempotent_id('84b99731-f748-44fe-a291-162d05da9e25')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported(
|
|
SHARE_REPLICA_QUOTAS_MICROVERSION)
|
|
def test_unlimited_user_quota_for_replica_quotas(self, quota_key):
|
|
kwargs = {quota_key: -1}
|
|
self.update_quotas(self.tenant_id, user_id=self.user_id, **kwargs)
|
|
|
|
quotas = self.client.show_quotas(
|
|
self.tenant_id, self.user_id)['quota_set']
|
|
|
|
self.assertEqual(-1, quotas.get(quota_key))
|
|
|
|
@ddt.data(11, -1)
|
|
@decorators.idempotent_id('43f58705-3cad-46bc-816c-41e8fa55dd8d')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
def test_update_user_quotas_bigger_than_project_quota(self, user_quota):
|
|
self.update_quotas(self.tenant_id, shares=10)
|
|
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
force=True,
|
|
shares=user_quota)
|
|
|
|
@ddt.data(11, -1)
|
|
@decorators.idempotent_id('315cb76f-920d-4cb9-ac7d-16be8e95e1b2')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported("2.39")
|
|
def test_update_share_type_quotas_bigger_than_project_quota(self, st_q):
|
|
share_type = self.create_share_type()
|
|
|
|
self.update_quotas(self.tenant_id, shares=10)
|
|
|
|
# no need to cleanup share type quota, share type will be deleted at
|
|
# the end of the test
|
|
self.update_quotas(self.tenant_id,
|
|
share_type=share_type['name'],
|
|
force=True,
|
|
cleanup=False,
|
|
shares=st_q)
|
|
|
|
@decorators.idempotent_id('c95be1eb-6331-4c37-9fac-ed6c36270457')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API)
|
|
@utils.skip_if_microversion_not_supported("2.39")
|
|
def test_set_share_type_quota_bigger_than_users_quota(self):
|
|
share_type = self.create_share_type()
|
|
|
|
self.update_quotas(self.tenant_id, force=False, shares=13)
|
|
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
force=True,
|
|
shares=11)
|
|
|
|
# Share type quota does not depend on user's quota, so we should be
|
|
# able to update it. No need for cleanup, since the share type will
|
|
# be deleted when the test completes, cleaning up quotas and usages
|
|
self.update_quotas(self.tenant_id,
|
|
share_type=share_type['name'],
|
|
force=False,
|
|
cleanup=False,
|
|
shares=12)
|
|
|
|
@decorators.idempotent_id('4687eb25-17b3-4995-ace2-62f8bda29c57')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API_WITH_BACKEND)
|
|
@utils.skip_if_microversion_not_supported("2.39")
|
|
def test_quotas_usages(self):
|
|
# Create share types
|
|
st_1, st_2 = (self.create_share_type()
|
|
for i in (1, 2))
|
|
|
|
# Set quotas for project, user and both share types
|
|
self.update_quotas(self.tenant_id, shares=3, gigabytes=10)
|
|
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
shares=2,
|
|
gigabytes=7)
|
|
|
|
for st in (st_1['id'], st_2['name']):
|
|
# no need for cleanup, since share types will be deleted at the
|
|
# end of the test
|
|
self.update_quotas(self.tenant_id,
|
|
share_type=st,
|
|
shares=2,
|
|
gigabytes=4,
|
|
cleanup=False)
|
|
|
|
# Create share, 4Gb, st1 - ok
|
|
share_1 = self.create_share(
|
|
size=4, share_type_id=st_1['id'], client=self.client,
|
|
cleanup_in_class=False)
|
|
|
|
# Try create shares twice, failing on user and share type quotas
|
|
for size, st_id in ((3, st_1['id']), (4, st_2['id'])):
|
|
self.assertRaises(
|
|
lib_exc.OverLimit,
|
|
self.create_share,
|
|
size=size, share_type_id=st_id, client=self.client,
|
|
cleanup_in_class=False)
|
|
|
|
# Create share, 3Gb, st2 - ok
|
|
share_2 = self.create_share(
|
|
size=3, share_type_id=st_2['id'], client=self.client,
|
|
cleanup_in_class=False)
|
|
|
|
# Check quota usages
|
|
for g_l, g_use, s_l, s_use, kwargs in (
|
|
(10, 7, 3, 2, {}),
|
|
(7, 7, 2, 2, {'user_id': self.user_id}),
|
|
(4, 4, 2, 1, {'share_type': st_1['id']}),
|
|
(4, 3, 2, 1, {'share_type': st_2['name']})):
|
|
quotas = self.client.detail_quotas(
|
|
tenant_id=self.tenant_id, **kwargs)['quota_set']
|
|
self.assertEqual(0, quotas['gigabytes']['reserved'])
|
|
self.assertEqual(g_l, quotas['gigabytes']['limit'])
|
|
self.assertEqual(g_use, quotas['gigabytes']['in_use'])
|
|
self.assertEqual(0, quotas['shares']['reserved'])
|
|
self.assertEqual(s_l, quotas['shares']['limit'])
|
|
self.assertEqual(s_use, quotas['shares']['in_use'])
|
|
|
|
# Delete shares and then check usages
|
|
for share_id in (share_1['id'], share_2['id']):
|
|
self.client.delete_share(share_id)
|
|
self.client.wait_for_resource_deletion(share_id=share_id)
|
|
for kwargs in ({}, {'share_type': st_1['name']},
|
|
{'user_id': self.user_id}, {'share_type': st_2['id']}):
|
|
quotas = self.client.detail_quotas(
|
|
tenant_id=self.tenant_id, **kwargs)['quota_set']
|
|
for key in ('shares', 'gigabytes'):
|
|
self.assertEqual(0, quotas[key]['reserved'])
|
|
self.assertEqual(0, quotas[key]['in_use'])
|
|
|
|
def _check_sg_usages(self, quotas, in_use, limit):
|
|
"""Helper method for 'test_share_group_quotas_usages' test."""
|
|
self.assertEqual(0, int(quotas['share_groups']['reserved']))
|
|
self.assertEqual(in_use, int(quotas['share_groups']['in_use']))
|
|
self.assertEqual(limit, int(quotas['share_groups']['limit']))
|
|
|
|
def _check_sgs_usages(self, quotas, in_use):
|
|
"""Helper method for 'test_share_group_quotas_usages' test."""
|
|
self.assertEqual(0, int(quotas['share_group_snapshots']['reserved']))
|
|
self.assertEqual(
|
|
in_use, int(quotas['share_group_snapshots']['in_use']))
|
|
self.assertEqual(1, int(quotas['share_group_snapshots']['limit']))
|
|
|
|
def _check_usages(self, sg_in_use, sgs_in_use):
|
|
"""Helper method for 'test_share_group_quotas_usages' test."""
|
|
p_quotas = self.client.detail_quotas(
|
|
tenant_id=self.tenant_id)['quota_set']
|
|
u_quotas = self.client.detail_quotas(
|
|
tenant_id=self.tenant_id, user_id=self.user_id)['quota_set']
|
|
self._check_sg_usages(p_quotas, sg_in_use, 3)
|
|
self._check_sg_usages(u_quotas, sg_in_use, 2)
|
|
self._check_sgs_usages(p_quotas, sgs_in_use)
|
|
self._check_sgs_usages(u_quotas, sgs_in_use)
|
|
|
|
@decorators.idempotent_id('fe357398-12d4-4a63-b5ae-0d5091ba3442')
|
|
@tc.attr(base.TAG_POSITIVE, base.TAG_API_WITH_BACKEND)
|
|
@testtools.skipUnless(
|
|
CONF.share.run_share_group_tests, 'Share Group tests disabled.')
|
|
@utils.skip_if_microversion_not_supported(SHARE_GROUPS_MICROVERSION)
|
|
@testtools.skipUnless(CONF.share.run_snapshot_tests,
|
|
"Snapshot tests are disabled.")
|
|
@testtools.skipUnless(
|
|
CONF.share.capability_create_share_from_snapshot_support,
|
|
"Tests for shares from snapshots are disabled.")
|
|
@utils.features('snapshot', 'share_from_snapshot')
|
|
def test_share_group_quotas_usages(self):
|
|
# Set quotas for project (3 SG, 1 SGS) and user (2 SG, 1 SGS)
|
|
self.update_quotas(self.tenant_id,
|
|
share_groups=3,
|
|
share_group_snapshots=1)
|
|
|
|
self.update_quotas(self.tenant_id,
|
|
user_id=self.user_id,
|
|
share_groups=2,
|
|
share_group_snapshots=1)
|
|
|
|
# Check usages, they should be 0s
|
|
self._check_usages(0, 0)
|
|
|
|
# Create SG1 and check usages
|
|
share_group1 = self.create_share_group(
|
|
share_group_type_id=self.share_group_type_id,
|
|
share_type_ids=[self.share_type_id],
|
|
cleanup_in_class=False,
|
|
client=self.client)
|
|
self._check_usages(1, 0)
|
|
|
|
# Create SGS1 and check usages
|
|
sg_snapshot = self.create_share_group_snapshot_wait_for_active(
|
|
share_group1['id'], cleanup_in_class=False, client=self.client)
|
|
self._check_usages(1, 1)
|
|
|
|
# Create SG2 from SGS1 and check usages
|
|
share_group2 = self.create_share_group(
|
|
share_group_type_id=self.share_group_type_id,
|
|
cleanup_in_class=False,
|
|
client=self.client,
|
|
source_share_group_snapshot_id=sg_snapshot['id'])
|
|
self._check_usages(2, 1)
|
|
|
|
# Try create SGS2, fail, then check usages
|
|
self.assertRaises(
|
|
lib_exc.OverLimit,
|
|
self.create_share_group,
|
|
share_group_type_id=self.share_group_type_id,
|
|
share_type_ids=[self.share_type_id],
|
|
client=self.client, cleanup_in_class=False)
|
|
self._check_usages(2, 1)
|
|
|
|
# Delete SG2 and check usages
|
|
self.client.delete_share_group(share_group2['id'])
|
|
self.client.wait_for_resource_deletion(
|
|
share_group_id=share_group2['id'])
|
|
self._check_usages(1, 1)
|
|
|
|
# Delete SGS1 and check usages
|
|
self.client.delete_share_group_snapshot(sg_snapshot['id'])
|
|
self.client.wait_for_resource_deletion(
|
|
share_group_snapshot_id=sg_snapshot['id'])
|
|
self._check_usages(1, 0)
|
|
|
|
# Delete SG1 and check usages
|
|
self.client.delete_share_group(share_group1['id'])
|
|
self.client.wait_for_resource_deletion(
|
|
share_group_id=share_group1['id'])
|
|
self._check_usages(0, 0)
|