Check all_tenants value in share_networks api

Add manila.utils.is_all_tenants to check all_tenants value.

Closes-Bug: #1777551
Change-Id: I1b66a25169cdd23a76bf76c799d04521fdf5f8e9
This commit is contained in:
hulina 2018-11-20 19:34:07 +08:00 committed by Goutham Pacha Ravi
parent b2787fded5
commit 34356e73b9
3 changed files with 37 additions and 1 deletions

View File

@ -33,6 +33,7 @@ from manila.i18n import _
from manila import policy from manila import policy
from manila import quota from manila import quota
from manila.share import rpcapi as share_rpcapi from manila.share import rpcapi as share_rpcapi
from manila import utils
RESOURCE_NAME = 'share_network' RESOURCE_NAME = 'share_network'
RESOURCES_NAME = 'share_networks' RESOURCES_NAME = 'share_networks'
@ -119,7 +120,7 @@ class ShareNetworkController(wsgi.Controller):
elif context.is_admin and 'project_id' in search_opts: elif context.is_admin and 'project_id' in search_opts:
networks = db_api.share_network_get_all_by_project( networks = db_api.share_network_get_all_by_project(
context, search_opts['project_id']) context, search_opts['project_id'])
elif context.is_admin and 'all_tenants' in search_opts: elif context.is_admin and utils.is_all_tenants(search_opts):
networks = db_api.share_network_get_all(context) networks = db_api.share_network_get_all(context)
else: else:
networks = db_api.share_network_get_all_by_project( networks = db_api.share_network_get_all_by_project(

View File

@ -408,6 +408,33 @@ class ShareNetworkAPITest(test.TestCase):
result[share_networks.RESOURCES_NAME][0], result[share_networks.RESOURCES_NAME][0],
fake_share_network_shortened) fake_share_network_shortened)
@mock.patch.object(db_api, 'share_network_get_all', mock.Mock())
def test_index_all_tenants_with_invaild_value(self):
req = fakes.HTTPRequest.blank(
'/share_networks?all_tenants=wonk',
use_admin_context=True)
self.assertRaises(exception.InvalidInput, self.controller.index, req)
@mock.patch.object(db_api, 'share_network_get_all_by_project', mock.Mock())
@mock.patch.object(db_api, 'share_network_get_all', mock.Mock())
def test_index_all_tenants_with_value_zero(self):
db_api.share_network_get_all_by_project.return_value = [
fake_share_network]
req = fakes.HTTPRequest.blank(
'/share_networks?all_tenants=0',
use_admin_context=True)
result = self.controller.index(req)
self.assertEqual(1, len(result[share_networks.RESOURCES_NAME]))
self._check_share_network_view_shortened(
result[share_networks.RESOURCES_NAME][0],
fake_share_network_shortened)
db_api.share_network_get_all_by_project.assert_called_once_with(
req.environ['manila.context'], self.context.project_id)
db_api.share_network_get_all.assert_not_called()
@mock.patch.object(db_api, 'share_network_get_all_by_project', mock.Mock()) @mock.patch.object(db_api, 'share_network_get_all_by_project', mock.Mock())
def test_index_filter_by_project_id_non_admin_context(self): def test_index_filter_by_project_id_non_admin_context(self):
req = fakes.HTTPRequest.blank( req = fakes.HTTPRequest.blank(

View File

@ -0,0 +1,8 @@
---
fixes:
- |
The ``all_tenants`` query parameter in the share networks API (GET
/v2/{project_id}/share-networks) has been fixed to accept 'f',
'false', 'off', 'n', 'no', or '0'. Setting the flag to any of these values
will retrieve security services only from the requester's project
namespace.