Files
freezer-api/freezer_api/tests/unit/test_exceptions.py
Volodymyr Mevsha e0ecbad03a Check client capabilities on job creation
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
2025-02-18 19:51:19 +00:00

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)