7d01bceaa0
Registers in-code the last remaining policy rules. Adds missing 'discoverable' rules. Without them, the extension_info API can fail, as it tries to check the os_compute_api:os_server_tags:discoverable rule. As it wasn't previously registered, when listing the available extensions, an exception of type PolicyNotRegistered is encountered. In order to validate this, functional/api_sample_tests/test_extension_info.py now runs without mocking policy.authorize. Switches extension_info to context.can. Switches nova.cells.filters to context.can. Switches network.neutronv2.api to context.can. Removes the rest of the entries in etc/policy.json. Removes DefaultPolicyTestCase, as it tests the default policy rule, which is not registered. Removes rules from fake_policy.py that brings no value, that are the same as the default values. Removes extensions authorizer factories. Removes nova.policy.enforce. Change-Id: Ie7771768f4f3efe0edc787c12f297aa93d533d7e Partially-Implements: bp policy-in-code
40 lines
1.5 KiB
Python
40 lines
1.5 KiB
Python
# Copyright 2012 Nebula, Inc.
|
|
# Copyright 2013 IBM Corp.
|
|
#
|
|
# 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 nova.tests.functional.api_sample_tests import api_sample_base
|
|
|
|
|
|
class ExtensionInfoAllSamplesJsonTest(api_sample_base.ApiSampleTestBaseV21):
|
|
sample_dir = "extension-info"
|
|
|
|
def test_list_extensions(self):
|
|
response = self._do_get('extensions')
|
|
# The full extension list is one of the places that things are
|
|
# different between the API versions and the legacy vs. new
|
|
# stack. We default to the v2.1 case.
|
|
template = 'extensions-list-resp'
|
|
if self.api_major_version == 'v2':
|
|
template = 'extensions-list-resp-v21-compatible'
|
|
|
|
self._verify_response(template, {}, response, 200)
|
|
|
|
|
|
class ExtensionInfoSamplesJsonTest(api_sample_base.ApiSampleTestBaseV21):
|
|
sample_dir = "extension-info"
|
|
|
|
def test_get_extensions(self):
|
|
response = self._do_get('extensions/os-agents')
|
|
self._verify_response('extensions-get-resp', {}, response, 200)
|