# Copyright 2015 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.common import waiters from manila_tempest_tests.tests.api import base from manila_tempest_tests import utils CONF = config.CONF @ddt.ddt class SharesActionsNegativeTest(base.BaseSharesMixedTest): @classmethod def resource_setup(cls): super(SharesActionsNegativeTest, cls).resource_setup() cls.admin_client = cls.admin_shares_v2_client cls.share_name = data_utils.rand_name("tempest-share-name") cls.share_desc = data_utils.rand_name("tempest-share-description") # create share_type extra_specs = {} if CONF.share.capability_snapshot_support: extra_specs.update({'snapshot_support': True}) cls.share_type = cls.create_share_type(extra_specs=extra_specs) cls.share_type_id = cls.share_type['id'] # create share cls.share = cls.create_share( name=cls.share_name, description=cls.share_desc, share_type_id=cls.share_type_id) if CONF.share.run_snapshot_tests: # create snapshot cls.snap_name = data_utils.rand_name("tempest-snapshot-name") cls.snap_desc = data_utils.rand_name( "tempest-snapshot-description") cls.snap = cls.create_snapshot_wait_for_active( cls.share["id"], cls.snap_name, cls.snap_desc) @decorators.idempotent_id('c4481ba3-0cff-448b-a728-69a9a34e3aa6') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_extend_tests, "Share extend tests are disabled.") @testtools.skipUnless( CONF.share.run_quota_tests, "Quota tests are disabled.") def test_share_extend_over_quota(self): tenant_quotas = self.shares_client.show_quotas( self.shares_client.tenant_id)['quota_set'] new_size = int(tenant_quotas["gigabytes"]) + 1 # extend share with over quota and check result self.assertRaises(lib_exc.Forbidden, self.shares_client.extend_share, self.share['id'], new_size) @decorators.idempotent_id('3448cd2b-34eb-453f-b72f-39fbea778e42') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_extend_tests, "Share extend tests are disabled.") def test_share_extend_with_less_size(self): new_size = int(self.share['size']) - 1 # extend share with invalid size and check result self.assertRaises(lib_exc.BadRequest, self.shares_client.extend_share, self.share['id'], new_size) @decorators.idempotent_id('79f2304a-7959-4169-8a76-b67814e0733a') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_extend_tests, "Share extend tests are disabled.") def test_share_extend_with_same_size(self): new_size = int(self.share['size']) # extend share with invalid size and check result self.assertRaises(lib_exc.BadRequest, self.shares_client.extend_share, self.share['id'], new_size) @decorators.idempotent_id('067c4b10-4324-45ac-8365-5d446b66c18a') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_extend_tests, "Share extend tests are disabled.") def test_share_extend_with_invalid_share_state(self): share = self.create_share(share_type_id=self.share_type_id, cleanup_in_class=False) new_size = int(share['size']) + 1 # set "error" state self.admin_client.reset_state(share['id']) # run extend operation on same share and check result self.assertRaises(lib_exc.BadRequest, self.shares_client.extend_share, share['id'], new_size) @decorators.idempotent_id('f9d2ba94-4032-d17a-b4ab-a2b67f650a39') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @utils.skip_if_microversion_not_supported("2.64") @testtools.skipUnless( CONF.share.run_extend_tests, "Share extend tests are disabled.") def test_share_force_extend_non_admin_user(self): # only admin cloud force extend share with micversion >= 2.64 # non-admin will get unauthorized error. new_size = int(self.share['size']) + 1 self.assertRaises(lib_exc.Forbidden, self.shares_v2_client.extend_share, self.share['id'], new_size, force=True) @decorators.idempotent_id('99d42f94-8da1-4c04-ad5b-9738d6acc139') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_shrink_tests, "Share shrink tests are disabled.") def test_share_shrink_with_greater_size(self): new_size = int(self.share['size']) + 1 # shrink share with invalid size and check result self.assertRaises(lib_exc.BadRequest, self.shares_client.shrink_share, self.share['id'], new_size) @decorators.idempotent_id('3d4c8f34-49b8-4628-b1cb-652ae67473a5') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_shrink_tests, "Share shrink tests are disabled.") def test_share_shrink_with_same_size(self): new_size = int(self.share['size']) # shrink share with invalid size and check result self.assertRaises(lib_exc.BadRequest, self.shares_client.shrink_share, self.share['id'], new_size) @decorators.idempotent_id('d53ece5c-70e4-4953-a1d7-7d4384510519') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @testtools.skipUnless( CONF.share.run_shrink_tests, "Share shrink tests are disabled.") def test_share_shrink_with_invalid_share_state(self): size = CONF.share.share_size + 1 share = self.create_share(share_type_id=self.share_type_id, size=size, cleanup_in_class=False) new_size = int(share['size']) - 1 # set "error" state self.admin_client.reset_state(share['id']) # run shrink operation on same share and check result self.assertRaises(lib_exc.BadRequest, self.shares_client.shrink_share, share['id'], new_size) @decorators.idempotent_id('ff307c91-3bb9-48b5-926c-5a2747320151') @tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND) @utils.skip_if_microversion_not_supported("2.34") @ddt.data('path', 'id') def test_list_shares_with_export_location_and_invalid_version( self, export_location_type): # In API versions