Add project name/ID validation for "openstack quota show"
A validation is necessary to check the existence of project. This patch is similar to Ia2d8c96527820e25b074e6486d3f39c5ad7eae60. Change-Id: Id8895ba7a21ecad05942619a82a87c0dc68eae53
This commit is contained in:
parent
27869c0f3f
commit
0ccd2a8108
@ -173,13 +173,19 @@ class ShowQuota(show.ShowOne):
|
|||||||
return parser
|
return parser
|
||||||
|
|
||||||
def get_compute_volume_quota(self, client, parsed_args):
|
def get_compute_volume_quota(self, client, parsed_args):
|
||||||
|
identity_client = self.app.client_manager.identity
|
||||||
|
project = utils.find_resource(
|
||||||
|
identity_client.projects,
|
||||||
|
parsed_args.project,
|
||||||
|
).id
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if parsed_args.quota_class:
|
if parsed_args.quota_class:
|
||||||
quota = client.quota_classes.get(parsed_args.project)
|
quota = client.quota_classes.get(project)
|
||||||
elif parsed_args.default:
|
elif parsed_args.default:
|
||||||
quota = client.quotas.defaults(parsed_args.project)
|
quota = client.quotas.defaults(project)
|
||||||
else:
|
else:
|
||||||
quota = client.quotas.get(parsed_args.project)
|
quota = client.quotas.get(project)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
if type(e).__name__ == 'EndpointNotFound':
|
if type(e).__name__ == 'EndpointNotFound':
|
||||||
return {}
|
return {}
|
||||||
|
@ -18,6 +18,7 @@ from openstackclient.common import quota
|
|||||||
from openstackclient.tests.compute.v2 import fakes as compute_fakes
|
from openstackclient.tests.compute.v2 import fakes as compute_fakes
|
||||||
from openstackclient.tests import fakes
|
from openstackclient.tests import fakes
|
||||||
from openstackclient.tests.identity.v2_0 import fakes as identity_fakes
|
from openstackclient.tests.identity.v2_0 import fakes as identity_fakes
|
||||||
|
from openstackclient.tests.network.v2 import fakes as network_fakes
|
||||||
|
|
||||||
|
|
||||||
class FakeQuotaResource(fakes.FakeResource):
|
class FakeQuotaResource(fakes.FakeResource):
|
||||||
@ -41,13 +42,23 @@ class TestQuota(compute_fakes.TestComputev2):
|
|||||||
super(TestQuota, self).setUp()
|
super(TestQuota, self).setUp()
|
||||||
self.quotas_mock = self.app.client_manager.compute.quotas
|
self.quotas_mock = self.app.client_manager.compute.quotas
|
||||||
self.quotas_mock.reset_mock()
|
self.quotas_mock.reset_mock()
|
||||||
|
self.quotas_class_mock = self.app.client_manager.compute.quota_classes
|
||||||
|
self.quotas_class_mock.reset_mock()
|
||||||
volume_mock = mock.Mock()
|
volume_mock = mock.Mock()
|
||||||
volume_mock.quotas = mock.Mock()
|
volume_mock.quotas = mock.Mock()
|
||||||
self.app.client_manager.volume = volume_mock
|
self.app.client_manager.volume = volume_mock
|
||||||
self.volume_quotas_mock = volume_mock.quotas
|
self.volume_quotas_mock = volume_mock.quotas
|
||||||
self.volume_quotas_mock.reset_mock()
|
self.volume_quotas_mock.reset_mock()
|
||||||
|
self.volume_quotas_class_mock = \
|
||||||
|
self.app.client_manager.volume.quota_classes
|
||||||
|
self.volume_quotas_class_mock.reset_mock()
|
||||||
self.projects_mock = self.app.client_manager.identity.projects
|
self.projects_mock = self.app.client_manager.identity.projects
|
||||||
self.projects_mock.reset_mock()
|
self.projects_mock.reset_mock()
|
||||||
|
self.app.client_manager.auth_ref = mock.Mock()
|
||||||
|
self.app.client_manager.auth_ref.service_catalog = mock.Mock()
|
||||||
|
self.service_catalog_mock = \
|
||||||
|
self.app.client_manager.auth_ref.service_catalog
|
||||||
|
self.service_catalog_mock.reset_mock()
|
||||||
|
|
||||||
|
|
||||||
class TestQuotaSet(TestQuota):
|
class TestQuotaSet(TestQuota):
|
||||||
@ -172,3 +183,113 @@ class TestQuotaSet(TestQuota):
|
|||||||
identity_fakes.project_id,
|
identity_fakes.project_id,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class TestQuotaShow(TestQuota):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestQuotaShow, self).setUp()
|
||||||
|
|
||||||
|
self.quotas_mock.get.return_value = FakeQuotaResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(compute_fakes.QUOTA),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.quotas_mock.defaults.return_value = FakeQuotaResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(compute_fakes.QUOTA),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.volume_quotas_mock.get.return_value = FakeQuotaResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(compute_fakes.QUOTA),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.volume_quotas_mock.defaults.return_value = FakeQuotaResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(compute_fakes.QUOTA),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.service_catalog_mock.get_endpoints.return_value = [
|
||||||
|
fakes.FakeResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(identity_fakes.ENDPOINT),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
]
|
||||||
|
|
||||||
|
self.quotas_class_mock.get.return_value = FakeQuotaResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(compute_fakes.QUOTA),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.volume_quotas_class_mock.get.return_value = FakeQuotaResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(compute_fakes.QUOTA),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.app.client_manager.network = network_fakes.FakeNetworkV2Client(
|
||||||
|
endpoint=fakes.AUTH_URL,
|
||||||
|
token=fakes.AUTH_TOKEN,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.cmd = quota.ShowQuota(self.app, None)
|
||||||
|
|
||||||
|
def test_quota_show(self):
|
||||||
|
arglist = [
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project', identity_fakes.project_name),
|
||||||
|
]
|
||||||
|
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
self.quotas_mock.get.assert_called_with(identity_fakes.project_id)
|
||||||
|
|
||||||
|
def test_quota_show_with_default(self):
|
||||||
|
arglist = [
|
||||||
|
'--default',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('default', True),
|
||||||
|
('project', identity_fakes.project_name),
|
||||||
|
]
|
||||||
|
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
self.quotas_mock.defaults.assert_called_with(identity_fakes.project_id)
|
||||||
|
|
||||||
|
def test_quota_show_with_class(self):
|
||||||
|
arglist = [
|
||||||
|
'--class',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('quota_class', True),
|
||||||
|
('project', identity_fakes.project_name),
|
||||||
|
]
|
||||||
|
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
self.quotas_class_mock.get.assert_called_with(
|
||||||
|
identity_fakes.project_id)
|
||||||
|
@ -95,6 +95,8 @@ class FakeComputev2Client(object):
|
|||||||
self.flavors.resource_class = fakes.FakeResource(None, {})
|
self.flavors.resource_class = fakes.FakeResource(None, {})
|
||||||
self.quotas = mock.Mock()
|
self.quotas = mock.Mock()
|
||||||
self.quotas.resource_class = fakes.FakeResource(None, {})
|
self.quotas.resource_class = fakes.FakeResource(None, {})
|
||||||
|
self.quota_classes = mock.Mock()
|
||||||
|
self.quota_classes.resource_class = fakes.FakeResource(None, {})
|
||||||
self.volumes = mock.Mock()
|
self.volumes = mock.Mock()
|
||||||
self.volumes.resource_class = fakes.FakeResource(None, {})
|
self.volumes.resource_class = fakes.FakeResource(None, {})
|
||||||
self.auth_token = kwargs['token']
|
self.auth_token = kwargs['token']
|
||||||
|
Loading…
Reference in New Issue
Block a user