8d71932c69
This new feature gives the user the ability to allow and deny access to the snapshots, so that they could be mounted in read-only mode to retrieve files. APIImpact DocImpact Co-Authored-By: Rodrigo Barbieri <rodrigo.barbieri@fit-tecnologia.org.br> Co-Authored-By: Alyson Rosa <alyson.rosa@fit-tecnologia.org.br> Co-Authored-By: Miriam Yumi <miriam.peixoto@fit-tecnologia.org.br> Partially-implements: blueprint manila-mountable-snapshots Change-Id: I65f398a05f82eef31ec317d70dfa101483b44b30
141 lines
5.4 KiB
Python
141 lines
5.4 KiB
Python
# Copyright (c) 2017 Hitachi Data Systems, 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 tempest import config
|
|
from tempest.lib import exceptions as lib_exc
|
|
import testtools
|
|
from testtools import testcase as tc
|
|
|
|
from manila_tempest_tests.tests.api import base
|
|
|
|
CONF = config.CONF
|
|
|
|
|
|
@base.skip_if_microversion_lt("2.32")
|
|
@testtools.skipUnless(CONF.share.run_mount_snapshot_tests and
|
|
CONF.share.run_snapshot_tests,
|
|
"Mountable snapshots tests are disabled.")
|
|
class SnapshotExportLocationsNegativeTest(base.BaseSharesMixedTest):
|
|
|
|
@classmethod
|
|
def setup_clients(cls):
|
|
super(SnapshotExportLocationsNegativeTest, cls).setup_clients()
|
|
cls.admin_client = cls.admin_shares_v2_client
|
|
cls.isolated_client = cls.alt_shares_v2_client
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(SnapshotExportLocationsNegativeTest, cls).resource_setup()
|
|
cls.share = cls.create_share(client=cls.admin_client)
|
|
cls.snapshot = cls.create_snapshot_wait_for_active(
|
|
cls.share['id'], client=cls.admin_client)
|
|
cls.snapshot = cls.admin_client.get_snapshot(cls.snapshot['id'])
|
|
cls.snapshot_instances = cls.admin_client.list_snapshot_instances(
|
|
snapshot_id=cls.snapshot['id'])
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND)
|
|
def test_get_inexistent_snapshot_export_location(self):
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.admin_client.get_snapshot_export_location,
|
|
self.snapshot['id'],
|
|
"fake-inexistent-snapshot-export-location-id",
|
|
)
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND)
|
|
def test_list_snapshot_export_locations_by_member(self):
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.isolated_client.list_snapshot_export_locations,
|
|
self.snapshot['id']
|
|
)
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND)
|
|
def test_get_snapshot_export_location_by_member(self):
|
|
export_locations = (
|
|
self.admin_client.list_snapshot_export_locations(
|
|
self.snapshot['id']))
|
|
|
|
for export_location in export_locations:
|
|
if export_location['is_admin_only']:
|
|
continue
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.isolated_client.get_snapshot_export_location,
|
|
self.snapshot['id'],
|
|
export_location['id']
|
|
)
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND)
|
|
def test_get_inexistent_snapshot_instance_export_location(self):
|
|
for snapshot_instance in self.snapshot_instances:
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.admin_client.get_snapshot_instance_export_location,
|
|
snapshot_instance['id'],
|
|
"fake-inexistent-snapshot-export-location-id",
|
|
)
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API_WITH_BACKEND)
|
|
def test_get_snapshot_instance_export_location_by_member(self):
|
|
for snapshot_instance in self.snapshot_instances:
|
|
export_locations = (
|
|
self.admin_client.list_snapshot_instance_export_locations(
|
|
snapshot_instance['id']))
|
|
for el in export_locations:
|
|
self.assertRaises(
|
|
lib_exc.Forbidden,
|
|
self.isolated_client.get_snapshot_instance_export_location,
|
|
snapshot_instance['id'], el['id'],
|
|
)
|
|
|
|
|
|
@testtools.skipUnless(CONF.share.run_mount_snapshot_tests and
|
|
CONF.share.run_snapshot_tests,
|
|
"Mountable snapshots tests are disabled.")
|
|
@base.skip_if_microversion_lt("2.32")
|
|
class SnapshotExportLocationsAPIOnlyNegativeTest(base.BaseSharesMixedTest):
|
|
|
|
@classmethod
|
|
def setup_clients(cls):
|
|
super(SnapshotExportLocationsAPIOnlyNegativeTest, cls).setup_clients()
|
|
cls.admin_client = cls.admin_shares_v2_client
|
|
cls.isolated_client = cls.alt_shares_v2_client
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API)
|
|
def test_list_export_locations_by_nonexistent_snapshot(self):
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.admin_client.list_snapshot_export_locations,
|
|
"fake-inexistent-snapshot-id",
|
|
)
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API)
|
|
def test_list_export_locations_by_nonexistent_snapshot_instance(self):
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.admin_client.list_snapshot_instance_export_locations,
|
|
"fake-inexistent-snapshot-instance-id",
|
|
)
|
|
|
|
@tc.attr(base.TAG_NEGATIVE, base.TAG_API)
|
|
def test_list_inexistent_snapshot_instance_export_locations_by_member(
|
|
self):
|
|
self.assertRaises(
|
|
lib_exc.Forbidden,
|
|
self.isolated_client.list_snapshot_instance_export_locations,
|
|
"fake-inexistent-snapshot-instance-id"
|
|
)
|