| # vim: tabstop=4 shiftwidth=4 softtabstop=4 |
| # |
| # Copyright 2012 NTT Data |
| # All Rights Reserved. |
| # |
| # 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 lxml import etree |
| |
| from tempest.common.rest_client import RestClientXML |
| from tempest.services.compute.xml.common import xml_to_json |
| |
| |
| class QuotasClientXML(RestClientXML): |
| |
| def __init__(self, config, username, password, auth_url, tenant_name=None): |
| super(QuotasClientXML, self).__init__(config, username, password, |
| auth_url, tenant_name) |
| self.service = self.config.compute.catalog_type |
| |
| def _format_quota(self, q): |
| quota = {} |
| for k, v in q.items(): |
| try: |
| v = int(v) |
| except ValueError: |
| pass |
| |
| quota[k] = v |
| |
| return quota |
| |
| def _parse_array(self, node): |
| return [self._format_quota(xml_to_json(x)) for x in node] |
| |
| def get_quota_set(self, tenant_id): |
| """List the quota set for a tenant.""" |
| |
| url = 'os-quota-sets/%s' % str(tenant_id) |
| resp, body = self.get(url, self.headers) |
| body = xml_to_json(etree.fromstring(body)) |
| body = self._format_quota(body) |
| return resp, body |