Scheduling backups of Cinder volumes using centralized instance(s) of freezer-scheduler requires executing tasks on behalf of the user. Client capabilities provide a mechanism to restrict which actions, modes, storages, and engines can be assigned to freezer-scheduler for security and workload control. The core implementation of client capabilities resides in freezer-scheduler. The primary purpose of checking capabilities on the freezer-api side is to prevent the assignment of actions that cannot be executed by a specific scheduler instance. Implements: blueprint centralized-scheduler Depends-On: I15a91e8232d07e5bbc2cc95a72b0405c61c64a72 Change-Id: Ie774f9e66ac373a43ef935775de3b18539c5bebd
73 lines
2.8 KiB
Python
73 lines
2.8 KiB
Python
# (c) Copyright 2014,2015 Hewlett-Packard Development Company, L.P.
|
|
#
|
|
# 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 falcon
|
|
from unittest import mock
|
|
|
|
from freezer_api.common import exceptions
|
|
from freezer_api.tests.unit import common
|
|
|
|
|
|
class TestExceptions(common.FreezerBaseTestCase):
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
self.ex = mock.Mock()
|
|
self.ex.message = 'test exception'
|
|
self.mock_req = mock.MagicMock()
|
|
self.mock_req.env.__getitem__.side_effect = common.get_req_items
|
|
self.mock_req.context = {}
|
|
|
|
def test_FreezerAPIException(self):
|
|
e = exceptions.FreezerAPIException(message='testing')
|
|
self.assertRaises(falcon.HTTPError,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|
|
|
|
def test_BadDataFormat(self):
|
|
e = exceptions.BadDataFormat(message='testing')
|
|
self.assertRaises(falcon.HTTPBadRequest,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|
|
|
|
def test_UnprocessableEntity(self):
|
|
e = exceptions.UnprocessableEntity(message='testing')
|
|
self.assertRaises(falcon.HTTPUnprocessableEntity,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|
|
|
|
def test_DocumentExists(self):
|
|
e = exceptions.DocumentExists(message='testing')
|
|
self.assertRaises(falcon.HTTPConflict,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|
|
|
|
def test_StorageEngineError(self):
|
|
e = exceptions.StorageEngineError(message='testing')
|
|
self.assertRaises(falcon.HTTPInternalServerError,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|
|
|
|
def test_DocumentNotFound(self):
|
|
e = exceptions.DocumentNotFound(message='testing')
|
|
self.assertRaises(falcon.HTTPError,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|
|
|
|
def test_AccessForbidden(self):
|
|
e = exceptions.AccessForbidden(message='testing')
|
|
self.assertRaises(falcon.HTTPForbidden,
|
|
e.handle, self.ex, self.mock_req, self.mock_req,
|
|
None)
|