Now that we no longer support py27, we can use the standard library
unittest.mock module instead of the third party mock lib.
The remainder was auto-generated with the following (hacky) script, with
one or two manual tweaks after the fact:
import glob
for path in glob.glob('watcher/tests/**/*.py', recursive=True):
with open(path) as fh:
lines = fh.readlines()
if 'import mock\n' not in lines:
continue
import_group_found = False
create_first_party_group = False
for num, line in enumerate(lines):
line = line.strip()
if line.startswith('import ') or line.startswith('from '):
tokens = line.split()
for lib in (
'ddt', 'six', 'webob', 'fixtures', 'testtools'
'neutron', 'cinder', 'ironic', 'keystone', 'oslo',
):
if lib in tokens[1]:
create_first_party_group = True
break
if create_first_party_group:
break
import_group_found = True
if not import_group_found:
continue
if line.startswith('import ') or line.startswith('from '):
tokens = line.split()
if tokens[1] > 'unittest':
break
elif tokens[1] == 'unittest' and (
len(tokens) == 2 or tokens[4] > 'mock'
):
break
elif not line:
break
if create_first_party_group:
lines.insert(num, 'from unittest import mock\n\n')
else:
lines.insert(num, 'from unittest import mock\n')
del lines[lines.index('import mock\n')]
with open(path, 'w+') as fh:
fh.writelines(lines)
Co-Authored-By: Sean McGinnis <sean.mcginnis@gmail.com>
Change-Id: Icf35d3a6c10c529e07d1a4edaa36f504e5bf553a
85 lines
3.1 KiB
Python
85 lines
3.1 KiB
Python
# Copyright 2019 ZTE corporation.
|
|
# 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 unittest import mock
|
|
|
|
from oslo_serialization import jsonutils
|
|
|
|
from watcher.decision_engine import rpcapi as deapi
|
|
from watcher.tests.api import base as api_base
|
|
|
|
|
|
class TestListDataModel(api_base.FunctionalTest):
|
|
|
|
def setUp(self):
|
|
super(TestListDataModel, self).setUp()
|
|
p_dcapi = mock.patch.object(deapi, 'DecisionEngineAPI')
|
|
self.mock_dcapi = p_dcapi.start()
|
|
self.mock_dcapi().get_data_model_info.return_value = \
|
|
'fake_response_value'
|
|
self.addCleanup(p_dcapi.stop)
|
|
|
|
def test_get_all(self):
|
|
response = self.get_json(
|
|
'/data_model/?data_model_type=compute',
|
|
headers={'OpenStack-API-Version': 'infra-optim 1.3'})
|
|
self.assertEqual('fake_response_value', response)
|
|
|
|
def test_get_all_not_acceptable(self):
|
|
response = self.get_json(
|
|
'/data_model/?data_model_type=compute',
|
|
headers={'OpenStack-API-Version': 'infra-optim 1.2'},
|
|
expect_errors=True)
|
|
self.assertEqual(406, response.status_int)
|
|
|
|
|
|
class TestDataModelPolicyEnforcement(api_base.FunctionalTest):
|
|
|
|
def setUp(self):
|
|
super(TestDataModelPolicyEnforcement, self).setUp()
|
|
p_dcapi = mock.patch.object(deapi, 'DecisionEngineAPI')
|
|
self.mock_dcapi = p_dcapi.start()
|
|
self.addCleanup(p_dcapi.stop)
|
|
|
|
def _common_policy_check(self, rule, func, *arg, **kwarg):
|
|
self.policy.set_rules({
|
|
"admin_api": "(role:admin or role:administrator)",
|
|
"default": "rule:admin_api",
|
|
rule: "rule:defaut"})
|
|
response = func(*arg, **kwarg)
|
|
self.assertEqual(403, response.status_int)
|
|
self.assertEqual('application/json', response.content_type)
|
|
self.assertTrue(
|
|
"Policy doesn't allow %s to be performed." % rule,
|
|
jsonutils.loads(response.json['error_message'])['faultstring'])
|
|
|
|
def test_policy_disallow_get_all(self):
|
|
self._common_policy_check(
|
|
"data_model:get_all", self.get_json,
|
|
"/data_model/?data_model_type=compute",
|
|
headers={'OpenStack-API-Version': 'infra-optim 1.3'},
|
|
expect_errors=True)
|
|
|
|
|
|
class TestDataModelEnforcementWithAdminContext(
|
|
TestListDataModel, api_base.AdminRoleTest):
|
|
|
|
def setUp(self):
|
|
super(TestDataModelEnforcementWithAdminContext, self).setUp()
|
|
self.policy.set_rules({
|
|
"admin_api": "(role:admin or role:administrator)",
|
|
"default": "rule:admin_api",
|
|
"data_model:get_all": "rule:default"})
|