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:
parent
b2787fded5
commit
34356e73b9
@ -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(
|
||||||
|
@ -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(
|
||||||
|
@ -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.
|
Loading…
Reference in New Issue
Block a user