Suppress policy deprecation and default change warnings

As part of the new policy work, all of the defaults for
policies were changed and warnings about it are being emitted
constantly in the logs. We can suppress these for now until we are
enforcing new defaults.

This also suppresses policy deprecation warnings during tests to avoid
filling the console with warning messages.

Change-Id: Ib2a7a2ed8bcadbb6a002cfa4b34c70910faa4f00
This commit is contained in:
Ghanshyam Mann 2021-08-18 10:44:33 -05:00
parent dd3155516c
commit 4b094df5cb
10 changed files with 90 additions and 44 deletions

View File

@ -45,8 +45,21 @@ opts.set_defaults(cfg.CONF, DEFAULT_POLICY_FILE)
class Enforcer(policy.Enforcer): class Enforcer(policy.Enforcer):
"""Responsible for loading and enforcing rules""" """Responsible for loading and enforcing rules"""
def __init__(self): def __init__(self, suppress_deprecation_warnings=False):
"""Init an policy Enforcer.
:param suppress_deprecation_warnings: Whether to suppress the
deprecation warnings.
"""
super(Enforcer, self).__init__(CONF, use_conf=True, overwrite=False) super(Enforcer, self).__init__(CONF, use_conf=True, overwrite=False)
# NOTE(gmann): Explictly disable the warnings for policies
# changing their default check_str. For new RBAC, all the policy
# defaults have been changed and warning for each policy started
# filling the logs limit for various tool.
# Once we move to new defaults only world then we can enable these
# warning again.
self.suppress_default_change_warnings = True
if suppress_deprecation_warnings:
self.suppress_deprecation_warnings = True
self.register_defaults(policies.list_rules()) self.register_defaults(policies.list_rules())
if CONF.enforce_secure_rbac and CONF.oslo_policy.enforce_new_defaults: if CONF.enforce_secure_rbac and CONF.oslo_policy.enforce_new_defaults:
LOG.warning(_LW( LOG.warning(_LW(

View File

@ -24,7 +24,7 @@ from glance.tests import functional
class TestImagesPolicy(functional.SynchronousAPIBase): class TestImagesPolicy(functional.SynchronousAPIBase):
def setUp(self): def setUp(self):
super(TestImagesPolicy, self).setUp() super(TestImagesPolicy, self).setUp()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
def set_policy_rules(self, rules): def set_policy_rules(self, rules):
self.policy.set_rules( self.policy.set_rules(

View File

@ -25,7 +25,7 @@ from glance.tests import functional
class TestImageMembersPolicy(functional.SynchronousAPIBase): class TestImageMembersPolicy(functional.SynchronousAPIBase):
def setUp(self): def setUp(self):
super(TestImageMembersPolicy, self).setUp() super(TestImageMembersPolicy, self).setUp()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
def load_data(self, share_image=False): def load_data(self, share_image=False):
output = {} output = {}

View File

@ -69,7 +69,7 @@ NAME_SPACE2 = {
class TestMetadefNamespacesPolicy(functional.SynchronousAPIBase): class TestMetadefNamespacesPolicy(functional.SynchronousAPIBase):
def setUp(self): def setUp(self):
super(TestMetadefNamespacesPolicy, self).setUp() super(TestMetadefNamespacesPolicy, self).setUp()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
def set_policy_rules(self, rules): def set_policy_rules(self, rules):
self.policy.set_rules( self.policy.set_rules(

View File

@ -54,7 +54,7 @@ NAME_SPACE1 = {
class TestMetadefObjectsPolicy(functional.SynchronousAPIBase): class TestMetadefObjectsPolicy(functional.SynchronousAPIBase):
def setUp(self): def setUp(self):
super(TestMetadefObjectsPolicy, self).setUp() super(TestMetadefObjectsPolicy, self).setUp()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
def load_data(self, create_objects=False): def load_data(self, create_objects=False):
path = '/v2/metadefs/namespaces' path = '/v2/metadefs/namespaces'

View File

@ -47,7 +47,7 @@ class TestProtectedImageRepoProxy(utils.BaseTestCase):
def setUp(self): def setUp(self):
super(TestProtectedImageRepoProxy, self).setUp() super(TestProtectedImageRepoProxy, self).setUp()
self.set_property_protections() self.set_property_protections()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
self.property_rules = property_utils.PropertyRules(self.policy) self.property_rules = property_utils.PropertyRules(self.policy)
self.image_factory = glance.domain.ImageFactory() self.image_factory = glance.domain.ImageFactory()
extra_props = {'spl_create_prop': 'c', extra_props = {'spl_create_prop': 'c',
@ -101,7 +101,7 @@ class TestProtectedImageProxy(utils.BaseTestCase):
def setUp(self): def setUp(self):
super(TestProtectedImageProxy, self).setUp() super(TestProtectedImageProxy, self).setUp()
self.set_property_protections() self.set_property_protections()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
self.property_rules = property_utils.PropertyRules(self.policy) self.property_rules = property_utils.PropertyRules(self.policy)
class ImageStub(object): class ImageStub(object):
@ -124,7 +124,7 @@ class TestExtraPropertiesProxy(utils.BaseTestCase):
def setUp(self): def setUp(self):
super(TestExtraPropertiesProxy, self).setUp() super(TestExtraPropertiesProxy, self).setUp()
self.set_property_protections() self.set_property_protections()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
self.property_rules = property_utils.PropertyRules(self.policy) self.property_rules = property_utils.PropertyRules(self.policy)
def test_read_extra_property_as_admin_role(self): def test_read_extra_property_as_admin_role(self):
@ -239,7 +239,7 @@ class TestProtectedImageFactoryProxy(utils.BaseTestCase):
def setUp(self): def setUp(self):
super(TestProtectedImageFactoryProxy, self).setUp() super(TestProtectedImageFactoryProxy, self).setUp()
self.set_property_protections() self.set_property_protections()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
self.property_rules = property_utils.PropertyRules(self.policy) self.property_rules = property_utils.PropertyRules(self.policy)
self.factory = glance.domain.ImageFactory() self.factory = glance.domain.ImageFactory()

View File

@ -55,7 +55,7 @@ class TestPropertyRulesWithRoles(base.IsolatedUnitTest):
def setUp(self): def setUp(self):
super(TestPropertyRulesWithRoles, self).setUp() super(TestPropertyRulesWithRoles, self).setUp()
self.set_property_protections() self.set_property_protections()
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
def test_is_property_protections_enabled_true(self): def test_is_property_protections_enabled_true(self):
self.config(property_protection_file="property-protections.conf") self.config(property_protection_file="property-protections.conf")
@ -329,7 +329,7 @@ class TestPropertyRulesWithPolicies(base.IsolatedUnitTest):
def setUp(self): def setUp(self):
super(TestPropertyRulesWithPolicies, self).setUp() super(TestPropertyRulesWithPolicies, self).setUp()
self.set_property_protections(use_policies=True) self.set_property_protections(use_policies=True)
self.policy = policy.Enforcer() self.policy = policy.Enforcer(suppress_deprecation_warnings=True)
self.rules_checker = property_utils.PropertyRules(self.policy) self.rules_checker = property_utils.PropertyRules(self.policy)
def test_check_property_rules_create_permitted_specific_policy(self): def test_check_property_rules_create_permitted_specific_policy(self):

View File

@ -171,7 +171,8 @@ class ProcessRequestTestCacheFilter(glance.api.middleware.cache.CacheFilter):
class TestCacheMiddlewareProcessRequest(base.IsolatedUnitTest): class TestCacheMiddlewareProcessRequest(base.IsolatedUnitTest):
def _enforcer_from_rules(self, unparsed_rules): def _enforcer_from_rules(self, unparsed_rules):
rules = policy.Rules.from_dict(unparsed_rules) rules = policy.Rules.from_dict(unparsed_rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
enforcer.set_rules(rules, overwrite=True) enforcer.set_rules(rules, overwrite=True)
return enforcer return enforcer
@ -363,7 +364,8 @@ class TestCacheMiddlewareProcessRequest(base.IsolatedUnitTest):
"download_image": "role:admin or rule:restricted" "download_image": "role:admin or rule:restricted"
} }
self.set_policy_rules(rules) self.set_policy_rules(rules)
cache_filter.policy = glance.api.policy.Enforcer() cache_filter.policy = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
actual = cache_filter.process_request(request) actual = cache_filter.process_request(request)
self.assertTrue(actual) self.assertTrue(actual)
@ -406,7 +408,8 @@ class TestCacheMiddlewareProcessResponse(base.IsolatedUnitTest):
"download_image": "role:admin or rule:restricted" "download_image": "role:admin or rule:restricted"
} }
self.set_policy_rules(rules) self.set_policy_rules(rules)
cache_filter.policy = glance.api.policy.Enforcer() cache_filter.policy = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
request = webob.Request.blank('/v2/images/test1/file') request = webob.Request.blank('/v2/images/test1/file')
request.context = context.RequestContext(roles=['_member_']) request.context = context.RequestContext(roles=['_member_'])
@ -443,7 +446,8 @@ class TestCacheMiddlewareProcessResponse(base.IsolatedUnitTest):
"download_image": "role:admin or rule:restricted" "download_image": "role:admin or rule:restricted"
} }
self.set_policy_rules(rules) self.set_policy_rules(rules)
cache_filter.policy = glance.api.policy.Enforcer() cache_filter.policy = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
request = webob.Request.blank('/v2/images/test1/file') request = webob.Request.blank('/v2/images/test1/file')
request.context = context.RequestContext(roles=['member']) request.context = context.RequestContext(roles=['member'])

View File

@ -258,7 +258,8 @@ class MdTagRepoStub(object):
class TestPolicyEnforcer(base.IsolatedUnitTest): class TestPolicyEnforcer(base.IsolatedUnitTest):
def test_policy_enforce_unregistered(self): def test_policy_enforce_unregistered(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(glance.api.policy.policy.PolicyNotRegistered, self.assertRaises(glance.api.policy.policy.PolicyNotRegistered,
@ -266,7 +267,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
context, 'wibble', {}) context, 'wibble', {})
def test_policy_check_unregistered(self): def test_policy_check_unregistered(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(glance.api.policy.policy.PolicyNotRegistered, self.assertRaises(glance.api.policy.policy.PolicyNotRegistered,
@ -274,7 +276,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
context, 'wibble', {}) context, 'wibble', {})
def test_policy_file_default_rules_default_location(self): def test_policy_file_default_rules_default_location(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=['reader']) context = glance.context.RequestContext(roles=['reader'])
enforcer.enforce(context, 'get_image', enforcer.enforce(context, 'get_image',
@ -284,7 +287,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
rules = {"get_image": '!'} rules = {"get_image": '!'}
self.set_policy_rules(rules) self.set_policy_rules(rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(exception.Forbidden, self.assertRaises(exception.Forbidden,
@ -297,7 +301,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
rules = {"get_image": '!'} rules = {"get_image": '!'}
self.set_policy_rules(rules) self.set_policy_rules(rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(exception.Forbidden, self.assertRaises(exception.Forbidden,
@ -310,7 +315,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
rules = {"get_image": '!'} rules = {"get_image": '!'}
self.set_policy_rules(rules) self.set_policy_rules(rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertEqual(False, enforcer.check(context, 'get_image', {})) self.assertEqual(False, enforcer.check(context, 'get_image', {}))
@ -319,7 +325,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
rules = {"default": ''} rules = {"default": ''}
self.set_policy_rules(rules) self.set_policy_rules(rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertEqual(True, enforcer.check(context, 'get_image', {})) self.assertEqual(True, enforcer.check(context, 'get_image', {}))
@ -328,7 +335,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
rules = {"default": '!'} rules = {"default": '!'}
self.set_policy_rules(rules) self.set_policy_rules(rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(exception.Forbidden, self.assertRaises(exception.Forbidden,
@ -339,7 +347,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
rule = common_policy.RuleDefault( rule = common_policy.RuleDefault(
name=policy_name, check_str='role:bar', scope_types=['system']) name=policy_name, check_str='role:bar', scope_types=['system'])
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
enforcer.register_default(rule) enforcer.register_default(rule)
context = glance.context.RequestContext( context = glance.context.RequestContext(
@ -368,7 +377,8 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
context = glance.context.RequestContext() context = glance.context.RequestContext()
mock_enforcer = self.mock_object(common_policy.Enforcer, 'enforce') mock_enforcer = self.mock_object(common_policy.Enforcer, 'enforce')
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
enforcer.register_default( enforcer.register_default(
common_policy.RuleDefault(name='foo', check_str='role:bar') common_policy.RuleDefault(name='foo', check_str='role:bar')
) )
@ -397,13 +407,15 @@ class TestPolicyEnforcer(base.IsolatedUnitTest):
"personas, specifically for system-scope." "personas, specifically for system-scope."
) )
with mock.patch.object(glance.api.policy, 'LOG') as mock_log: with mock.patch.object(glance.api.policy, 'LOG') as mock_log:
glance.api.policy.Enforcer() glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
mock_log.warning.assert_called_once_with(expected_log_string) mock_log.warning.assert_called_once_with(expected_log_string)
def test_ensure_experimental_warning_is_not_logged_for_legacy_rbac(self): def test_ensure_experimental_warning_is_not_logged_for_legacy_rbac(self):
self.config(enforce_new_defaults=False, group='oslo_policy') self.config(enforce_new_defaults=False, group='oslo_policy')
with mock.patch.object(glance.api.policy, 'LOG') as mock_log: with mock.patch.object(glance.api.policy, 'LOG') as mock_log:
glance.api.policy.Enforcer() glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
mock_log.warning.assert_not_called() mock_log.warning.assert_not_called()
@ -413,7 +425,8 @@ class TestPolicyEnforcerNoFile(base.IsolatedUnitTest):
"""Missing defined policy file should result in a default ruleset""" """Missing defined policy file should result in a default ruleset"""
self.config(policy_file='gobble.gobble', group='oslo_policy') self.config(policy_file='gobble.gobble', group='oslo_policy')
self.config(enforce_new_defaults=True, group='oslo_policy') self.config(enforce_new_defaults=True, group='oslo_policy')
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(exception.Forbidden, self.assertRaises(exception.Forbidden,
@ -433,7 +446,8 @@ class TestPolicyEnforcerNoFile(base.IsolatedUnitTest):
self.mock_object(oslo_config.cfg.ConfigOpts, 'find_file', self.mock_object(oslo_config.cfg.ConfigOpts, 'find_file',
fake_find_file) fake_find_file)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[]) context = glance.context.RequestContext(roles=[])
self.assertRaises(exception.Forbidden, self.assertRaises(exception.Forbidden,
@ -1029,7 +1043,8 @@ class TestContextPolicyEnforcer(base.IsolatedUnitTest):
rules = {'context_is_admin': 'role:%s' % policy_admin_role} rules = {'context_is_admin': 'role:%s' % policy_admin_role}
self.set_policy_rules(rules) self.set_policy_rules(rules)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
context = glance.context.RequestContext(roles=[context_role], context = glance.context.RequestContext(roles=[context_role],
is_admin=context_is_admin, is_admin=context_is_admin,

View File

@ -1552,7 +1552,8 @@ class TestImagesController(base.IsolatedUnitTest):
self.controller.update, request, UUID1, changes) self.controller.update, request, UUID1, changes)
def test_prop_protection_with_create_and_permitted_role(self): def test_prop_protection_with_create_and_permitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1573,7 +1574,8 @@ class TestImagesController(base.IsolatedUnitTest):
def test_prop_protection_with_update_and_permitted_policy(self): def test_prop_protection_with_update_and_permitted_policy(self):
self.set_property_protections(use_policies=True) self.set_property_protections(use_policies=True)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1601,7 +1603,8 @@ class TestImagesController(base.IsolatedUnitTest):
def test_prop_protection_with_create_with_patch_and_policy(self): def test_prop_protection_with_create_with_patch_and_policy(self):
self.set_property_protections(use_policies=True) self.set_property_protections(use_policies=True)
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1627,7 +1630,8 @@ class TestImagesController(base.IsolatedUnitTest):
output.extra_properties['spl_creator_policy']) output.extra_properties['spl_creator_policy'])
def test_prop_protection_with_create_and_unpermitted_role(self): def test_prop_protection_with_create_and_unpermitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1648,7 +1652,8 @@ class TestImagesController(base.IsolatedUnitTest):
created_image.image_id, changes) created_image.image_id, changes)
def test_prop_protection_with_show_and_permitted_role(self): def test_prop_protection_with_show_and_permitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1666,7 +1671,8 @@ class TestImagesController(base.IsolatedUnitTest):
self.assertEqual('bar', output.extra_properties['x_owner_foo']) self.assertEqual('bar', output.extra_properties['x_owner_foo'])
def test_prop_protection_with_show_and_unpermitted_role(self): def test_prop_protection_with_show_and_unpermitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1685,7 +1691,8 @@ class TestImagesController(base.IsolatedUnitTest):
'x_owner_foo') 'x_owner_foo')
def test_prop_protection_with_update_and_permitted_role(self): def test_prop_protection_with_update_and_permitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1706,7 +1713,8 @@ class TestImagesController(base.IsolatedUnitTest):
self.assertEqual('baz', output.extra_properties['x_owner_foo']) self.assertEqual('baz', output.extra_properties['x_owner_foo'])
def test_prop_protection_with_update_and_unpermitted_role(self): def test_prop_protection_with_update_and_unpermitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1726,7 +1734,8 @@ class TestImagesController(base.IsolatedUnitTest):
another_request, created_image.image_id, changes) another_request, created_image.image_id, changes)
def test_prop_protection_with_delete_and_permitted_role(self): def test_prop_protection_with_delete_and_permitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1748,7 +1757,8 @@ class TestImagesController(base.IsolatedUnitTest):
'x_owner_foo') 'x_owner_foo')
def test_prop_protection_with_delete_and_unpermitted_role(self): def test_prop_protection_with_delete_and_unpermitted_role(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1768,7 +1778,8 @@ class TestImagesController(base.IsolatedUnitTest):
another_request, created_image.image_id, changes) another_request, created_image.image_id, changes)
def test_create_protected_prop_case_insensitive(self): def test_create_protected_prop_case_insensitive(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1788,7 +1799,8 @@ class TestImagesController(base.IsolatedUnitTest):
self.assertEqual('1', output.extra_properties['x_case_insensitive']) self.assertEqual('1', output.extra_properties['x_case_insensitive'])
def test_read_protected_prop_case_insensitive(self): def test_read_protected_prop_case_insensitive(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1806,7 +1818,8 @@ class TestImagesController(base.IsolatedUnitTest):
self.assertEqual('1', output.extra_properties['x_case_insensitive']) self.assertEqual('1', output.extra_properties['x_case_insensitive'])
def test_update_protected_prop_case_insensitive(self): def test_update_protected_prop_case_insensitive(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,
@ -1827,7 +1840,8 @@ class TestImagesController(base.IsolatedUnitTest):
self.assertEqual('2', output.extra_properties['x_case_insensitive']) self.assertEqual('2', output.extra_properties['x_case_insensitive'])
def test_delete_protected_prop_case_insensitive(self): def test_delete_protected_prop_case_insensitive(self):
enforcer = glance.api.policy.Enforcer() enforcer = glance.api.policy.Enforcer(
suppress_deprecation_warnings=True)
self.controller = glance.api.v2.images.ImagesController(self.db, self.controller = glance.api.v2.images.ImagesController(self.db,
enforcer, enforcer,
self.notifier, self.notifier,