
Now we moved all code to the new enginefacade so we don't need this check anymore. And BTW. I think it wasn't working properly as even if we are using new facade we still see plenty of those warnings in e.g. logs of the neutron functional tests CI job. Partially-Implements blueprint: enginefacade-switch Change-Id: Ib2933e4f52e8d7585c13a0d1a3485389fa37b432
233 lines
9.8 KiB
Python
233 lines
9.8 KiB
Python
# 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_config import cfg
|
|
from oslo_context import context as oslo_context
|
|
from testtools import matchers
|
|
|
|
from neutron_lib import context
|
|
from neutron_lib.tests import _base
|
|
|
|
|
|
class TestNeutronContext(_base.BaseTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestNeutronContext, self).setUp()
|
|
db_api = 'neutron_lib.db.api.get_writer_session'
|
|
self._db_api_session_patcher = mock.patch(db_api)
|
|
self.db_api_session = self._db_api_session_patcher.start()
|
|
|
|
def test_neutron_context_create(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
self.assertEqual('user_id', ctx.user_id)
|
|
self.assertEqual('tenant_id', ctx.project_id)
|
|
self.assertEqual('tenant_id', ctx.tenant_id)
|
|
request_id = ctx.request_id
|
|
if isinstance(request_id, bytes):
|
|
request_id = request_id.decode('utf-8')
|
|
self.assertThat(request_id, matchers.StartsWith('req-'))
|
|
self.assertEqual('user_id', ctx.user)
|
|
self.assertEqual('tenant_id', ctx.tenant)
|
|
self.assertIsNone(ctx.user_name)
|
|
self.assertIsNone(ctx.tenant_name)
|
|
self.assertIsNone(ctx.project_name)
|
|
self.assertIsNone(ctx.auth_token)
|
|
|
|
def test_neutron_context_getter_setter(self):
|
|
ctx = context.Context('Anakin', 'Skywalker')
|
|
self.assertEqual('Anakin', ctx.user_id)
|
|
self.assertEqual('Skywalker', ctx.tenant_id)
|
|
ctx.user_id = 'Darth'
|
|
ctx.tenant_id = 'Vader'
|
|
self.assertEqual('Darth', ctx.user_id)
|
|
self.assertEqual('Vader', ctx.tenant_id)
|
|
|
|
def test_neutron_context_create_with_name(self):
|
|
ctx = context.Context('user_id', 'tenant_id',
|
|
tenant_name='tenant_name', user_name='user_name')
|
|
# Check name is set
|
|
self.assertEqual('user_name', ctx.user_name)
|
|
self.assertEqual('tenant_name', ctx.tenant_name)
|
|
self.assertEqual('tenant_name', ctx.project_name)
|
|
# Check user/tenant contains its ID even if user/tenant_name is passed
|
|
self.assertEqual('user_id', ctx.user)
|
|
self.assertEqual('tenant_id', ctx.tenant)
|
|
|
|
def test_neutron_context_create_with_request_id(self):
|
|
ctx = context.Context('user_id', 'tenant_id', request_id='req_id_xxx')
|
|
self.assertEqual('req_id_xxx', ctx.request_id)
|
|
|
|
def test_neutron_context_create_with_timestamp(self):
|
|
now = "Right Now!"
|
|
ctx = context.Context('user_id', 'tenant_id', timestamp=now)
|
|
self.assertEqual(now, ctx.timestamp)
|
|
|
|
def test_neutron_context_create_is_advsvc(self):
|
|
ctx = context.Context('user_id', 'tenant_id', is_advsvc=True)
|
|
self.assertFalse(ctx.is_admin)
|
|
self.assertTrue(ctx.is_advsvc)
|
|
|
|
def test_neutron_context_create_with_auth_token(self):
|
|
ctx = context.Context('user_id', 'tenant_id',
|
|
auth_token='auth_token_xxx')
|
|
self.assertEqual('auth_token_xxx', ctx.auth_token)
|
|
|
|
def test_neutron_context_from_dict(self):
|
|
owner = {'user_id': 'Luke', 'tenant_id': 'Skywalker'}
|
|
ctx = context.Context.from_dict(owner)
|
|
self.assertEqual(owner['user_id'], ctx.user_id)
|
|
self.assertEqual(owner['tenant_id'], ctx.tenant_id)
|
|
|
|
def test_neutron_context_to_dict(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
ctx_dict = ctx.to_dict()
|
|
self.assertEqual('user_id', ctx_dict['user_id'])
|
|
self.assertEqual('tenant_id', ctx_dict['project_id'])
|
|
self.assertEqual(ctx.request_id, ctx_dict['request_id'])
|
|
self.assertEqual('user_id', ctx_dict['user'])
|
|
self.assertEqual('tenant_id', ctx_dict['tenant'])
|
|
self.assertIsNone(ctx_dict['user_name'])
|
|
self.assertIsNone(ctx_dict['tenant_name'])
|
|
self.assertIsNone(ctx_dict['project_name'])
|
|
self.assertIsNone(ctx_dict['auth_token'])
|
|
|
|
def test_neutron_context_to_dict_with_name(self):
|
|
ctx = context.Context('user_id', 'tenant_id',
|
|
tenant_name='tenant_name',
|
|
user_name='user_name')
|
|
ctx_dict = ctx.to_dict()
|
|
self.assertEqual('user_name', ctx_dict['user_name'])
|
|
self.assertEqual('tenant_name', ctx_dict['tenant_name'])
|
|
self.assertEqual('tenant_name', ctx_dict['project_name'])
|
|
|
|
def test_neutron_context_to_dict_with_auth_token(self):
|
|
ctx = context.Context('user_id', 'tenant_id',
|
|
auth_token='auth_token_xxx')
|
|
ctx_dict = ctx.to_dict()
|
|
self.assertEqual('auth_token_xxx', ctx_dict['auth_token'])
|
|
|
|
def test_neutron_context_admin_to_dict(self):
|
|
self.db_api_session.return_value = 'fakesession'
|
|
ctx = context.get_admin_context()
|
|
ctx_dict = ctx.to_dict()
|
|
self.assertIsNone(ctx_dict['user_id'])
|
|
self.assertIsNone(ctx_dict['tenant_id'])
|
|
self.assertIsNone(ctx_dict['auth_token'])
|
|
self.assertTrue(ctx_dict['is_admin'])
|
|
self.assertIsNotNone(ctx.session)
|
|
self.assertNotIn('session', ctx_dict)
|
|
|
|
def test_neutron_context_admin_without_session_to_dict(self):
|
|
ctx = context.get_admin_context_without_session()
|
|
ctx_dict = ctx.to_dict()
|
|
self.assertIsNone(ctx_dict['user_id'])
|
|
self.assertIsNone(ctx_dict['tenant_id'])
|
|
self.assertIsNone(ctx_dict['auth_token'])
|
|
self.assertFalse(hasattr(ctx, 'session'))
|
|
|
|
def test_neutron_context_elevated_retains_request_id(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
self.assertFalse(ctx.is_admin)
|
|
req_id_before = ctx.request_id
|
|
|
|
elevated_ctx = ctx.elevated()
|
|
self.assertTrue(elevated_ctx.is_admin)
|
|
self.assertEqual(req_id_before, elevated_ctx.request_id)
|
|
|
|
def test_neutron_context_elevated_idempotent(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
self.assertFalse(ctx.is_admin)
|
|
elevated_ctx = ctx.elevated()
|
|
self.assertTrue(elevated_ctx.is_admin)
|
|
elevated2_ctx = elevated_ctx.elevated()
|
|
self.assertTrue(elevated2_ctx.is_admin)
|
|
|
|
def test_neutron_context_elevated_system_scope_for_new_policies(self):
|
|
cfg.CONF.set_override(
|
|
'enforce_new_defaults', True, group='oslo_policy')
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
self.assertFalse(ctx.is_admin)
|
|
self.assertNotEqual('all', ctx.system_scope)
|
|
elevated_ctx = ctx.elevated()
|
|
self.assertTrue(elevated_ctx.is_admin)
|
|
self.assertEqual('all', elevated_ctx.system_scope)
|
|
|
|
def test_neutron_context_overwrite(self):
|
|
ctx1 = context.Context('user_id', 'tenant_id')
|
|
self.assertEqual(ctx1.request_id,
|
|
oslo_context.get_current().request_id)
|
|
|
|
# If overwrite is not specified, request_id should be updated.
|
|
ctx2 = context.Context('user_id', 'tenant_id')
|
|
self.assertNotEqual(ctx2.request_id, ctx1.request_id)
|
|
self.assertEqual(ctx2.request_id,
|
|
oslo_context.get_current().request_id)
|
|
|
|
# If overwrite is specified, request_id should be kept.
|
|
ctx3 = context.Context('user_id', 'tenant_id', overwrite=False)
|
|
self.assertNotEqual(ctx3.request_id, ctx2.request_id)
|
|
self.assertEqual(ctx2.request_id,
|
|
oslo_context.get_current().request_id)
|
|
|
|
def test_neutron_context_get_admin_context_not_update_local_store(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
req_id_before = oslo_context.get_current().request_id
|
|
self.assertEqual(ctx.request_id, req_id_before)
|
|
|
|
ctx_admin = context.get_admin_context()
|
|
self.assertEqual(req_id_before, oslo_context.get_current().request_id)
|
|
self.assertNotEqual(req_id_before, ctx_admin.request_id)
|
|
|
|
def test_to_policy_values(self):
|
|
values = {
|
|
'user_id': 'user_id',
|
|
'tenant_id': 'tenant_id',
|
|
'is_admin': 'is_admin',
|
|
'tenant_name': 'tenant_name',
|
|
'user_name': 'user_name',
|
|
'domain': 'domain',
|
|
'user_domain': 'user_domain',
|
|
'project_domain': 'project_domain',
|
|
'user_name': 'user_name',
|
|
}
|
|
additional_values = {
|
|
'user': 'user_id',
|
|
'tenant': 'tenant_id',
|
|
'project_id': 'tenant_id',
|
|
'project_name': 'tenant_name',
|
|
}
|
|
ctx = context.Context(**values)
|
|
# apply dict() to get a real dictionary, needed for newer oslo.context
|
|
# that returns _DeprecatedPolicyValues object instead
|
|
policy_values = dict(ctx.to_policy_values())
|
|
self.assertDictSupersetOf(values, policy_values)
|
|
self.assertDictSupersetOf(additional_values, policy_values)
|
|
|
|
def test_session_cached(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
session1 = ctx.session
|
|
session2 = ctx.session
|
|
self.assertIs(session1, session2)
|
|
|
|
def test_add_get_remove_constraint(self):
|
|
ctx = context.Context('user_id', 'tenant_id')
|
|
self.assertIsNone(ctx.get_transaction_constraint())
|
|
ctx.set_transaction_constraint('networks', 'net_id', 44)
|
|
constraint = ctx.get_transaction_constraint()
|
|
self.assertEqual(44, constraint.if_revision_match)
|
|
self.assertEqual('networks', constraint.resource)
|
|
self.assertEqual('net_id', constraint.resource_id)
|
|
ctx.clear_transaction_constraint()
|
|
self.assertIsNone(ctx.get_transaction_constraint())
|