Merge "pre-commit: Bump mypy"
This commit is contained in:
commit
9172a043a3
@ -37,7 +37,7 @@ repos:
|
|||||||
- flake8-import-order~=0.18.2
|
- flake8-import-order~=0.18.2
|
||||||
exclude: '^(doc|releasenotes|tools)/.*$'
|
exclude: '^(doc|releasenotes|tools)/.*$'
|
||||||
- repo: https://github.com/pre-commit/mirrors-mypy
|
- repo: https://github.com/pre-commit/mirrors-mypy
|
||||||
rev: v1.10.1
|
rev: v1.11.2
|
||||||
hooks:
|
hooks:
|
||||||
- id: mypy
|
- id: mypy
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
|
@ -64,6 +64,8 @@ class AcceleratorRequest(resource.Resource):
|
|||||||
has_body=True,
|
has_body=True,
|
||||||
retry_on_conflict=None,
|
retry_on_conflict=None,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
|
*,
|
||||||
|
microversion=None,
|
||||||
):
|
):
|
||||||
# This overrides the default behavior of patch because
|
# This overrides the default behavior of patch because
|
||||||
# the PATCH method consumes a dict rather than a list. spec:
|
# the PATCH method consumes a dict rather than a list. spec:
|
||||||
@ -104,7 +106,7 @@ class AcceleratorRequest(resource.Resource):
|
|||||||
attrs = attrs[self.resources_key][0]
|
attrs = attrs[self.resources_key][0]
|
||||||
return super()._consume_attrs(mapping, attrs)
|
return super()._consume_attrs(mapping, attrs)
|
||||||
|
|
||||||
def create(self, session, base_path=None):
|
def create(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# This overrides the default behavior of resource creation because
|
# This overrides the default behavior of resource creation because
|
||||||
# cyborg doesn't accept resource_key in its request.
|
# cyborg doesn't accept resource_key in its request.
|
||||||
return super().create(session, prepend_key=False, base_path=base_path)
|
return super().create(session, prepend_key, *args, **kwargs)
|
||||||
|
@ -38,11 +38,19 @@ class DeviceProfile(resource.Resource):
|
|||||||
|
|
||||||
# TODO(s_shogo): This implementation only treat [ DeviceProfile ], and
|
# TODO(s_shogo): This implementation only treat [ DeviceProfile ], and
|
||||||
# cannot treat multiple DeviceProfiles in list.
|
# cannot treat multiple DeviceProfiles in list.
|
||||||
def _prepare_request_body(self, patch, prepend_key):
|
def _prepare_request_body(
|
||||||
body = super()._prepare_request_body(patch, prepend_key)
|
self,
|
||||||
|
patch,
|
||||||
|
prepend_key,
|
||||||
|
*,
|
||||||
|
resource_request_key=None,
|
||||||
|
):
|
||||||
|
body = super()._prepare_request_body(
|
||||||
|
patch, prepend_key, resource_request_key=resource_request_key
|
||||||
|
)
|
||||||
return [body]
|
return [body]
|
||||||
|
|
||||||
def create(self, session, base_path=None):
|
def create(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# This overrides the default behavior of resource creation because
|
# This overrides the default behavior of resource creation because
|
||||||
# cyborg doesn't accept resource_key in its request.
|
# cyborg doesn't accept resource_key in its request.
|
||||||
return super().create(session, prepend_key=False, base_path=base_path)
|
return super().create(session, prepend_key, *args, **kwargs)
|
||||||
|
@ -1465,6 +1465,8 @@ class Node(_common.Resource):
|
|||||||
has_body=True,
|
has_body=True,
|
||||||
retry_on_conflict=None,
|
retry_on_conflict=None,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
|
*,
|
||||||
|
microversion=None,
|
||||||
reset_interfaces=None,
|
reset_interfaces=None,
|
||||||
):
|
):
|
||||||
if reset_interfaces is not None:
|
if reset_interfaces is not None:
|
||||||
|
@ -60,7 +60,7 @@ class Group(resource.Resource):
|
|||||||
exceptions.raise_from_response(response)
|
exceptions.raise_from_response(response)
|
||||||
return response
|
return response
|
||||||
|
|
||||||
def delete(self, session, *, delete_volumes=False):
|
def delete(self, session, *args, delete_volumes=False, **kwargs):
|
||||||
"""Delete a group."""
|
"""Delete a group."""
|
||||||
body = {'delete': {'delete-volumes': delete_volumes}}
|
body = {'delete': {'delete-volumes': delete_volumes}}
|
||||||
self._action(session, body)
|
self._action(session, body)
|
||||||
|
@ -90,11 +90,12 @@ class Service(resource.Resource):
|
|||||||
f"No {cls.__name__} found for {name_or_id}"
|
f"No {cls.__name__} found for {name_or_id}"
|
||||||
)
|
)
|
||||||
|
|
||||||
def commit(self, session, prepend_key=False, **kwargs):
|
def commit(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# we need to set prepend_key to false
|
# we need to set prepend_key to false
|
||||||
return super().commit(
|
return super().commit(
|
||||||
session,
|
session,
|
||||||
prepend_key=prepend_key,
|
prepend_key,
|
||||||
|
*args,
|
||||||
**kwargs,
|
**kwargs,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -359,7 +359,9 @@ class Volume(resource.Resource, metadata.MetadataMixin):
|
|||||||
|
|
||||||
self._action(session, body)
|
self._action(session, body)
|
||||||
|
|
||||||
def _prepare_request_body(self, patch, prepend_key):
|
def _prepare_request_body(
|
||||||
|
self, patch, prepend_key, *, resource_request_key=None
|
||||||
|
):
|
||||||
body = self._body.dirty
|
body = self._body.dirty
|
||||||
# Scheduler hints is external to the standard volume request
|
# Scheduler hints is external to the standard volume request
|
||||||
# so pass it separately and not under the volume JSON object.
|
# so pass it separately and not under the volume JSON object.
|
||||||
|
@ -16,7 +16,7 @@ from openstack import resource
|
|||||||
|
|
||||||
|
|
||||||
class AsyncResource(resource.Resource):
|
class AsyncResource(resource.Resource):
|
||||||
def delete(self, session, error_message=None):
|
def delete(self, session, error_message=None, **kwargs):
|
||||||
"""Delete the remote resource based on this instance.
|
"""Delete the remote resource based on this instance.
|
||||||
|
|
||||||
:param session: The session to use for making this request.
|
:param session: The session to use for making this request.
|
||||||
|
@ -55,17 +55,31 @@ class QuotaSet(resource.Resource):
|
|||||||
requires_id=False,
|
requires_id=False,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
|
skip_cache=False,
|
||||||
|
*,
|
||||||
|
resource_response_key=None,
|
||||||
|
microversion=None,
|
||||||
**params,
|
**params,
|
||||||
):
|
):
|
||||||
return super().fetch(
|
return super().fetch(
|
||||||
session,
|
session,
|
||||||
requires_id=False,
|
requires_id,
|
||||||
base_path=base_path,
|
base_path,
|
||||||
error_message=error_message,
|
error_message,
|
||||||
|
skip_cache,
|
||||||
|
resource_response_key=resource_response_key,
|
||||||
|
microversion=microversion,
|
||||||
**params,
|
**params,
|
||||||
)
|
)
|
||||||
|
|
||||||
def _translate_response(self, response, has_body=None, error_message=None):
|
def _translate_response(
|
||||||
|
self,
|
||||||
|
response,
|
||||||
|
has_body=None,
|
||||||
|
error_message=None,
|
||||||
|
*,
|
||||||
|
resource_response_key=None,
|
||||||
|
):
|
||||||
"""Given a KSA response, inflate this instance with its data
|
"""Given a KSA response, inflate this instance with its data
|
||||||
|
|
||||||
DELETE operations don't return a body, so only try to work
|
DELETE operations don't return a body, so only try to work
|
||||||
@ -127,7 +141,13 @@ class QuotaSet(resource.Resource):
|
|||||||
self._update_location()
|
self._update_location()
|
||||||
dict.update(self, self.to_dict())
|
dict.update(self, self.to_dict())
|
||||||
|
|
||||||
def _prepare_request_body(self, patch, prepend_key):
|
def _prepare_request_body(
|
||||||
|
self,
|
||||||
|
patch,
|
||||||
|
prepend_key,
|
||||||
|
*,
|
||||||
|
resource_request_key=None,
|
||||||
|
):
|
||||||
body = self._body.dirty
|
body = self._body.dirty
|
||||||
# Ensure we never try to send meta props reservation and usage
|
# Ensure we never try to send meta props reservation and usage
|
||||||
body.pop('reservation', None)
|
body.pop('reservation', None)
|
||||||
|
@ -52,7 +52,7 @@ class TagMixin:
|
|||||||
self._body.attributes.update({'tags': json['tags']})
|
self._body.attributes.update({'tags': json['tags']})
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def set_tags(self, session, tags=[]):
|
def set_tags(self, session, tags):
|
||||||
"""Sets/Replaces all tags on the resource.
|
"""Sets/Replaces all tags on the resource.
|
||||||
|
|
||||||
:param session: The session to use for making this request.
|
:param session: The session to use for making this request.
|
||||||
|
@ -121,8 +121,8 @@ class Limits(resource.Resource):
|
|||||||
self,
|
self,
|
||||||
session,
|
session,
|
||||||
requires_id=False,
|
requires_id=False,
|
||||||
error_message=None,
|
|
||||||
base_path=None,
|
base_path=None,
|
||||||
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
**params,
|
**params,
|
||||||
):
|
):
|
||||||
@ -137,10 +137,10 @@ class Limits(resource.Resource):
|
|||||||
# TODO(mordred) We shouldn't have to subclass just to declare
|
# TODO(mordred) We shouldn't have to subclass just to declare
|
||||||
# requires_id = False.
|
# requires_id = False.
|
||||||
return super().fetch(
|
return super().fetch(
|
||||||
session=session,
|
session,
|
||||||
requires_id=requires_id,
|
requires_id,
|
||||||
error_message=error_message,
|
error_message,
|
||||||
base_path=base_path,
|
base_path,
|
||||||
skip_cache=skip_cache,
|
skip_cache,
|
||||||
**params,
|
**params,
|
||||||
)
|
)
|
||||||
|
@ -280,13 +280,18 @@ class Server(resource.Resource, metadata.MetadataMixin, tag.TagMixin):
|
|||||||
self,
|
self,
|
||||||
requires_id=True,
|
requires_id=True,
|
||||||
prepend_key=True,
|
prepend_key=True,
|
||||||
|
patch=False,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
|
params=None,
|
||||||
**kwargs,
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = super()._prepare_request(
|
request = super()._prepare_request(
|
||||||
requires_id=requires_id,
|
requires_id=requires_id,
|
||||||
prepend_key=prepend_key,
|
prepend_key=prepend_key,
|
||||||
|
patch=patch,
|
||||||
base_path=base_path,
|
base_path=base_path,
|
||||||
|
params=params,
|
||||||
|
**kwargs,
|
||||||
)
|
)
|
||||||
|
|
||||||
server_body = request.body[self.resource_key]
|
server_body = request.body[self.resource_key]
|
||||||
|
@ -87,13 +87,9 @@ class Service(resource.Resource):
|
|||||||
f"No {cls.__name__} found for {name_or_id}"
|
f"No {cls.__name__} found for {name_or_id}"
|
||||||
)
|
)
|
||||||
|
|
||||||
def commit(self, session, prepend_key=False, **kwargs):
|
def commit(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# we need to set prepend_key to false
|
# we need to set prepend_key to false
|
||||||
return super().commit(
|
return super().commit(session, prepend_key, *args, **kwargs)
|
||||||
session,
|
|
||||||
prepend_key=prepend_key,
|
|
||||||
**kwargs,
|
|
||||||
)
|
|
||||||
|
|
||||||
def _action(self, session, action, body, microversion=None):
|
def _action(self, session, action, body, microversion=None):
|
||||||
if not microversion:
|
if not microversion:
|
||||||
|
@ -35,7 +35,13 @@ class User(resource.Resource):
|
|||||||
password = resource.Body('password')
|
password = resource.Body('password')
|
||||||
|
|
||||||
def _prepare_request(
|
def _prepare_request(
|
||||||
self, requires_id=True, prepend_key=True, base_path=None, **kwargs
|
self,
|
||||||
|
requires_id=True,
|
||||||
|
prepend_key=True,
|
||||||
|
patch=False,
|
||||||
|
base_path=None,
|
||||||
|
*args,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
"""Prepare a request for the database service's create call
|
"""Prepare a request for the database service's create call
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ class ZoneExport(_base.Resource):
|
|||||||
#: ID for the zone that was created by this export
|
#: ID for the zone that was created by this export
|
||||||
zone_id = resource.Body('zone_id')
|
zone_id = resource.Body('zone_id')
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(self, session, prepend_key=True, base_path=None, **kwargs):
|
||||||
"""Create a remote resource based on this instance.
|
"""Create a remote resource based on this instance.
|
||||||
|
|
||||||
:param session: The session to use for making this request.
|
:param session: The session to use for making this request.
|
||||||
|
@ -51,7 +51,7 @@ class ZoneImport(_base.Resource):
|
|||||||
#: ID for the zone that was created by this import
|
#: ID for the zone that was created by this import
|
||||||
zone_id = resource.Body('zone_id')
|
zone_id = resource.Body('zone_id')
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(self, session, prepend_key=True, base_path=None, **kwargs):
|
||||||
"""Create a remote resource based on this instance.
|
"""Create a remote resource based on this instance.
|
||||||
|
|
||||||
:param session: The session to use for making this request.
|
:param session: The session to use for making this request.
|
||||||
|
@ -47,7 +47,13 @@ class Limit(resource.Resource):
|
|||||||
#: ID of project. *Type: string*
|
#: ID of project. *Type: string*
|
||||||
project_id = resource.Body('project_id')
|
project_id = resource.Body('project_id')
|
||||||
|
|
||||||
def _prepare_request_body(self, patch, prepend_key):
|
def _prepare_request_body(
|
||||||
|
self,
|
||||||
|
patch,
|
||||||
|
prepend_key,
|
||||||
|
*,
|
||||||
|
resource_request_key=None,
|
||||||
|
):
|
||||||
body = self._body.dirty
|
body = self._body.dirty
|
||||||
if prepend_key and self.resource_key is not None:
|
if prepend_key and self.resource_key is not None:
|
||||||
if patch:
|
if patch:
|
||||||
|
@ -45,7 +45,13 @@ class RegisteredLimit(resource.Resource):
|
|||||||
#: The default limit value. *Type: int*
|
#: The default limit value. *Type: int*
|
||||||
default_limit = resource.Body('default_limit')
|
default_limit = resource.Body('default_limit')
|
||||||
|
|
||||||
def _prepare_request_body(self, patch, prepend_key):
|
def _prepare_request_body(
|
||||||
|
self,
|
||||||
|
patch,
|
||||||
|
prepend_key,
|
||||||
|
*,
|
||||||
|
resource_request_key=None,
|
||||||
|
):
|
||||||
body = self._body.dirty
|
body = self._body.dirty
|
||||||
if prepend_key and self.resource_key is not None:
|
if prepend_key and self.resource_key is not None:
|
||||||
if patch:
|
if patch:
|
||||||
|
@ -54,7 +54,9 @@ class Cache(resource.Resource):
|
|||||||
exceptions.raise_from_response(response)
|
exceptions.raise_from_response(response)
|
||||||
return response
|
return response
|
||||||
|
|
||||||
def clear(self, session, target='both'):
|
# FIXME(stephenfin): This needs to be renamed as it conflicts with
|
||||||
|
# dict.clear
|
||||||
|
def clear(self, session, target='both'): # type: ignore[override]
|
||||||
"""Clears the cache.
|
"""Clears the cache.
|
||||||
:param session: The session to use for making this request
|
:param session: The session to use for making this request
|
||||||
:param target: Specify which target you want to clear
|
:param target: Specify which target you want to clear
|
||||||
|
@ -383,6 +383,7 @@ class Image(resource.Resource, tag.TagMixin, _download.DownloadMixin):
|
|||||||
prepend_key=False,
|
prepend_key=False,
|
||||||
patch=False,
|
patch=False,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
|
params=None,
|
||||||
**kwargs,
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = super()._prepare_request(
|
request = super()._prepare_request(
|
||||||
@ -390,6 +391,8 @@ class Image(resource.Resource, tag.TagMixin, _download.DownloadMixin):
|
|||||||
prepend_key=prepend_key,
|
prepend_key=prepend_key,
|
||||||
patch=patch,
|
patch=patch,
|
||||||
base_path=base_path,
|
base_path=base_path,
|
||||||
|
params=params,
|
||||||
|
**kwargs,
|
||||||
)
|
)
|
||||||
if patch:
|
if patch:
|
||||||
headers = {
|
headers = {
|
||||||
|
@ -91,6 +91,7 @@ class Secret(resource.Resource):
|
|||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=requires_id, base_path=base_path
|
requires_id=requires_id, base_path=base_path
|
||||||
|
@ -111,10 +111,12 @@ class AmphoraConfig(resource.Resource):
|
|||||||
#: The ID of the amphora.
|
#: The ID of the amphora.
|
||||||
amphora_id = resource.URI('amphora_id')
|
amphora_id = resource.URI('amphora_id')
|
||||||
|
|
||||||
# The default _update code path also has no
|
# The default _update code path also has no way to pass has_body into this
|
||||||
# way to pass has_body into this function, so overriding the method here.
|
# function, so overriding the method here.
|
||||||
def commit(self, session, base_path=None):
|
def commit(
|
||||||
return super().commit(session, base_path=base_path, has_body=False)
|
self, session, prepend_key=True, has_body=False, *args, **kwargs
|
||||||
|
):
|
||||||
|
return super().commit(session, prepend_key, has_body, *args, *kwargs)
|
||||||
|
|
||||||
|
|
||||||
class AmphoraFailover(resource.Resource):
|
class AmphoraFailover(resource.Resource):
|
||||||
@ -134,7 +136,9 @@ class AmphoraFailover(resource.Resource):
|
|||||||
#: The ID of the amphora.
|
#: The ID of the amphora.
|
||||||
amphora_id = resource.URI('amphora_id')
|
amphora_id = resource.URI('amphora_id')
|
||||||
|
|
||||||
# The default _update code path also has no
|
# The default _update code path also has no way to pass has_body into this
|
||||||
# way to pass has_body into this function, so overriding the method here.
|
# function, so overriding the method here.
|
||||||
def commit(self, session, base_path=None):
|
def commit(
|
||||||
return super().commit(session, base_path=base_path, has_body=False)
|
self, session, prepend_key=True, has_body=False, *args, **kwargs
|
||||||
|
):
|
||||||
|
return super().commit(session, prepend_key, has_body, *args, *kwargs)
|
||||||
|
@ -83,7 +83,7 @@ class LoadBalancer(resource.Resource, tag.TagMixin):
|
|||||||
#: Additional VIPs
|
#: Additional VIPs
|
||||||
additional_vips = resource.Body('additional_vips', type=list)
|
additional_vips = resource.Body('additional_vips', type=list)
|
||||||
|
|
||||||
def delete(self, session, error_message=None):
|
def delete(self, session, error_message=None, **kwargs):
|
||||||
request = self._prepare_request()
|
request = self._prepare_request()
|
||||||
params = {}
|
params = {}
|
||||||
if (
|
if (
|
||||||
@ -145,5 +145,7 @@ class LoadBalancerFailover(resource.Resource):
|
|||||||
|
|
||||||
# The default _update code path also has no
|
# The default _update code path also has no
|
||||||
# way to pass has_body into this function, so overriding the method here.
|
# way to pass has_body into this function, so overriding the method here.
|
||||||
def commit(self, session, base_path=None):
|
def commit(
|
||||||
return super().commit(session, base_path=base_path, has_body=False)
|
self, session, prepend_key=True, has_body=False, *args, **kwargs
|
||||||
|
):
|
||||||
|
return super().commit(session, prepend_key, has_body, *args, **kwargs)
|
||||||
|
@ -42,7 +42,13 @@ class Quota(resource.Resource):
|
|||||||
project_id = resource.Body('project_id', alternate_id=True)
|
project_id = resource.Body('project_id', alternate_id=True)
|
||||||
|
|
||||||
def _prepare_request(
|
def _prepare_request(
|
||||||
self, requires_id=True, base_path=None, prepend_key=False, **kwargs
|
self,
|
||||||
|
requires_id=True,
|
||||||
|
prepend_key=False,
|
||||||
|
patch=False,
|
||||||
|
base_path=None,
|
||||||
|
*args,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
_request = super()._prepare_request(
|
_request = super()._prepare_request(
|
||||||
requires_id, prepend_key, base_path=base_path
|
requires_id, prepend_key, base_path=base_path
|
||||||
|
@ -55,13 +55,25 @@ class Claim(resource.Resource):
|
|||||||
#: authentication is not enabled in Zaqar service.
|
#: authentication is not enabled in Zaqar service.
|
||||||
project_id = resource.Header("X-PROJECT-ID")
|
project_id = resource.Header("X-PROJECT-ID")
|
||||||
|
|
||||||
def _translate_response(self, response, has_body=True):
|
def _translate_response(
|
||||||
super()._translate_response(response, has_body=has_body)
|
self,
|
||||||
|
response,
|
||||||
|
has_body=None,
|
||||||
|
error_message=None,
|
||||||
|
*,
|
||||||
|
resource_response_key=None,
|
||||||
|
):
|
||||||
|
super()._translate_response(
|
||||||
|
response,
|
||||||
|
has_body,
|
||||||
|
error_message,
|
||||||
|
resource_response_key=resource_response_key,
|
||||||
|
)
|
||||||
if has_body and self.location:
|
if has_body and self.location:
|
||||||
# Extract claim ID from location
|
# Extract claim ID from location
|
||||||
self.id = self.location.split("claims/")[1]
|
self.id = self.location.split("claims/")[1]
|
||||||
|
|
||||||
def create(self, session, prepend_key=False, base_path=None):
|
def create(self, session, prepend_key=False, base_path=None, **kwargs):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=False, prepend_key=prepend_key, base_path=base_path
|
requires_id=False, prepend_key=prepend_key, base_path=base_path
|
||||||
)
|
)
|
||||||
@ -89,6 +101,7 @@ class Claim(resource.Resource):
|
|||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=requires_id, base_path=base_path
|
requires_id=requires_id, base_path=base_path
|
||||||
@ -107,7 +120,13 @@ class Claim(resource.Resource):
|
|||||||
return self
|
return self
|
||||||
|
|
||||||
def commit(
|
def commit(
|
||||||
self, session, prepend_key=False, has_body=False, base_path=None
|
self,
|
||||||
|
session,
|
||||||
|
prepend_key=True,
|
||||||
|
has_body=True,
|
||||||
|
retry_on_conflict=None,
|
||||||
|
base_path=None,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
prepend_key=prepend_key, base_path=base_path
|
prepend_key=prepend_key, base_path=base_path
|
||||||
@ -122,7 +141,7 @@ class Claim(resource.Resource):
|
|||||||
|
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def delete(self, session):
|
def delete(self, session, *args, **kwargs):
|
||||||
request = self._prepare_request()
|
request = self._prepare_request()
|
||||||
headers = {
|
headers = {
|
||||||
"Client-ID": self.client_id or str(uuid.uuid4()),
|
"Client-ID": self.client_id or str(uuid.uuid4()),
|
||||||
|
@ -123,6 +123,7 @@ class Message(resource.Resource):
|
|||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=requires_id, base_path=base_path
|
requires_id=requires_id, base_path=base_path
|
||||||
@ -140,7 +141,9 @@ class Message(resource.Resource):
|
|||||||
|
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def delete(self, session):
|
def delete(
|
||||||
|
self, session, error_message=None, *, microversion=None, **kwargs
|
||||||
|
):
|
||||||
request = self._prepare_request()
|
request = self._prepare_request()
|
||||||
headers = {
|
headers = {
|
||||||
"Client-ID": self.client_id or str(uuid.uuid4()),
|
"Client-ID": self.client_id or str(uuid.uuid4()),
|
||||||
|
@ -50,7 +50,7 @@ class Queue(resource.Resource):
|
|||||||
#: in case keystone auth is not enabled in Zaqar service.
|
#: in case keystone auth is not enabled in Zaqar service.
|
||||||
project_id = resource.Header("X-PROJECT-ID")
|
project_id = resource.Header("X-PROJECT-ID")
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(self, session, prepend_key=False, base_path=None, **kwargs):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=True, prepend_key=prepend_key, base_path=None
|
requires_id=True, prepend_key=prepend_key, base_path=None
|
||||||
)
|
)
|
||||||
@ -117,6 +117,7 @@ class Queue(resource.Resource):
|
|||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=requires_id, base_path=base_path
|
requires_id=requires_id, base_path=base_path
|
||||||
@ -133,7 +134,9 @@ class Queue(resource.Resource):
|
|||||||
|
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def delete(self, session):
|
def delete(
|
||||||
|
self, session, error_message=None, *, microversion=None, **kwargs
|
||||||
|
):
|
||||||
request = self._prepare_request()
|
request = self._prepare_request()
|
||||||
headers = {
|
headers = {
|
||||||
"Client-ID": self.client_id or str(uuid.uuid4()),
|
"Client-ID": self.client_id or str(uuid.uuid4()),
|
||||||
|
@ -58,7 +58,7 @@ class Subscription(resource.Resource):
|
|||||||
#: authentication is not enabled in Zaqar service.
|
#: authentication is not enabled in Zaqar service.
|
||||||
project_id = resource.Header("X-PROJECT-ID")
|
project_id = resource.Header("X-PROJECT-ID")
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(self, session, prepend_key=False, base_path=None, **kwargs):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=False, prepend_key=prepend_key, base_path=base_path
|
requires_id=False, prepend_key=prepend_key, base_path=base_path
|
||||||
)
|
)
|
||||||
@ -125,6 +125,7 @@ class Subscription(resource.Resource):
|
|||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=requires_id, base_path=base_path
|
requires_id=requires_id, base_path=base_path
|
||||||
@ -142,7 +143,9 @@ class Subscription(resource.Resource):
|
|||||||
|
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def delete(self, session):
|
def delete(
|
||||||
|
self, session, error_message=None, *, microversion=None, **kwargs
|
||||||
|
):
|
||||||
request = self._prepare_request()
|
request = self._prepare_request()
|
||||||
headers = {
|
headers = {
|
||||||
"Client-ID": self.client_id or str(uuid.uuid4()),
|
"Client-ID": self.client_id or str(uuid.uuid4()),
|
||||||
|
@ -25,6 +25,7 @@ class NetworkResource(resource.Resource):
|
|||||||
patch=False,
|
patch=False,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
params=None,
|
params=None,
|
||||||
|
*,
|
||||||
if_revision=None,
|
if_revision=None,
|
||||||
**kwargs,
|
**kwargs,
|
||||||
):
|
):
|
||||||
|
@ -61,7 +61,13 @@ class Quota(resource.Resource):
|
|||||||
security_groups = resource.Body('security_group', type=int)
|
security_groups = resource.Body('security_group', type=int)
|
||||||
|
|
||||||
def _prepare_request(
|
def _prepare_request(
|
||||||
self, requires_id=True, prepend_key=False, base_path=None, **kwargs
|
self,
|
||||||
|
requires_id=True,
|
||||||
|
prepend_key=False,
|
||||||
|
patch=False,
|
||||||
|
base_path=None,
|
||||||
|
*args,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
_request = super()._prepare_request(requires_id, prepend_key)
|
_request = super()._prepare_request(requires_id, prepend_key)
|
||||||
if self.resource_key in _request.body:
|
if self.resource_key in _request.body:
|
||||||
|
@ -40,8 +40,8 @@ class BaseResource(resource.Resource):
|
|||||||
else:
|
else:
|
||||||
self.metadata[k] = v
|
self.metadata[k] = v
|
||||||
|
|
||||||
def _prepare_request(self, **kwargs):
|
def _prepare_request(self, *args, **kwargs):
|
||||||
request = super()._prepare_request(**kwargs)
|
request = super()._prepare_request(*args, **kwargs)
|
||||||
request.headers.update(self._calculate_headers(self.metadata))
|
request.headers.update(self._calculate_headers(self.metadata))
|
||||||
return request
|
return request
|
||||||
|
|
||||||
@ -91,7 +91,14 @@ class BaseResource(resource.Resource):
|
|||||||
key = header[len(self._custom_metadata_prefix) :].lower()
|
key = header[len(self._custom_metadata_prefix) :].lower()
|
||||||
self.metadata[key] = headers[header]
|
self.metadata[key] = headers[header]
|
||||||
|
|
||||||
def _translate_response(self, response, has_body=None, error_message=None):
|
def _translate_response(
|
||||||
|
self,
|
||||||
|
response,
|
||||||
|
has_body=None,
|
||||||
|
error_message=None,
|
||||||
|
*,
|
||||||
|
resource_response_key=None,
|
||||||
|
):
|
||||||
# Save headers of the last operation for potential use (get_object of
|
# Save headers of the last operation for potential use (get_object of
|
||||||
# cloud layer).
|
# cloud layer).
|
||||||
# This must happen before invoking parent _translate_response, cause it
|
# This must happen before invoking parent _translate_response, cause it
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
|
|
||||||
from calendar import timegm
|
from calendar import timegm
|
||||||
import collections
|
import collections
|
||||||
|
import functools
|
||||||
from hashlib import sha1
|
from hashlib import sha1
|
||||||
import hmac
|
import hmac
|
||||||
import json
|
import json
|
||||||
@ -56,6 +57,7 @@ class Proxy(proxy.Proxy):
|
|||||||
|
|
||||||
log = _log.setup_logging('openstack')
|
log = _log.setup_logging('openstack')
|
||||||
|
|
||||||
|
@functools.lru_cache(maxsize=256)
|
||||||
def _extract_name(self, url, service_type=None, project_id=None):
|
def _extract_name(self, url, service_type=None, project_id=None):
|
||||||
url_path = parse.urlparse(url).path.strip()
|
url_path = parse.urlparse(url).path.strip()
|
||||||
# Remove / from the beginning to keep the list indexes of interesting
|
# Remove / from the beginning to keep the list indexes of interesting
|
||||||
|
@ -123,7 +123,7 @@ class Container(_base.BaseResource):
|
|||||||
kwargs.setdefault('name', name)
|
kwargs.setdefault('name', name)
|
||||||
return cls(_synchronized=False, **kwargs)
|
return cls(_synchronized=False, **kwargs)
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(self, session, prepend_key=True, base_path=None, **kwargs):
|
||||||
"""Create a remote resource based on this instance.
|
"""Create a remote resource based on this instance.
|
||||||
|
|
||||||
:param session: The session to use for making this request.
|
:param session: The session to use for making this request.
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import re
|
import re
|
||||||
import urllib
|
import urllib.parse
|
||||||
|
|
||||||
from openstack import exceptions
|
from openstack import exceptions
|
||||||
from openstack import resource
|
from openstack import resource
|
||||||
@ -58,8 +58,9 @@ class Info(resource.Resource):
|
|||||||
session,
|
session,
|
||||||
requires_id=False,
|
requires_id=False,
|
||||||
base_path=None,
|
base_path=None,
|
||||||
skip_cache=False,
|
|
||||||
error_message=None,
|
error_message=None,
|
||||||
|
skip_cache=False,
|
||||||
|
**kwargs,
|
||||||
):
|
):
|
||||||
"""Get a remote resource based on this instance.
|
"""Get a remote resource based on this instance.
|
||||||
|
|
||||||
|
@ -213,7 +213,7 @@ class Object(_base.BaseResource):
|
|||||||
# The Object Store treats the metadata for its resources inconsistently so
|
# The Object Store treats the metadata for its resources inconsistently so
|
||||||
# Object.set_metadata must override the BaseResource.set_metadata to
|
# Object.set_metadata must override the BaseResource.set_metadata to
|
||||||
# account for it.
|
# account for it.
|
||||||
def set_metadata(self, session, metadata):
|
def set_metadata(self, session, metadata, refresh=True):
|
||||||
# Filter out items with empty values so the create metadata behaviour
|
# Filter out items with empty values so the create metadata behaviour
|
||||||
# is the same as account and container
|
# is the same as account and container
|
||||||
filtered_metadata = {
|
filtered_metadata = {
|
||||||
@ -321,7 +321,7 @@ class Object(_base.BaseResource):
|
|||||||
)
|
)
|
||||||
return response.iter_content(chunk_size, decode_unicode=False)
|
return response.iter_content(chunk_size, decode_unicode=False)
|
||||||
|
|
||||||
def create(self, session, base_path=None, **params):
|
def create(self, session, prepend_key=True, base_path=None, **kwargs):
|
||||||
request = self._prepare_request(base_path=base_path)
|
request = self._prepare_request(base_path=base_path)
|
||||||
|
|
||||||
response = session.put(
|
response = session.put(
|
||||||
@ -330,11 +330,11 @@ class Object(_base.BaseResource):
|
|||||||
self._translate_response(response, has_body=False)
|
self._translate_response(response, has_body=False)
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def _raw_delete(self, session, microversion=None):
|
def _raw_delete(self, session, microversion=None, **kwargs):
|
||||||
if not self.allow_delete:
|
if not self.allow_delete:
|
||||||
raise exceptions.MethodNotSupported(self, "delete")
|
raise exceptions.MethodNotSupported(self, 'delete')
|
||||||
|
|
||||||
request = self._prepare_request()
|
request = self._prepare_request(**kwargs)
|
||||||
session = self._get_session(session)
|
session = self._get_session(session)
|
||||||
if microversion is None:
|
if microversion is None:
|
||||||
microversion = self._get_microversion(session, action='delete')
|
microversion = self._get_microversion(session, action='delete')
|
||||||
@ -349,5 +349,7 @@ class Object(_base.BaseResource):
|
|||||||
headers['multipart-manifest'] = 'delete'
|
headers['multipart-manifest'] = 'delete'
|
||||||
|
|
||||||
return session.delete(
|
return session.delete(
|
||||||
request.url, headers=headers, microversion=microversion
|
request.url,
|
||||||
|
headers=headers,
|
||||||
|
microversion=microversion,
|
||||||
)
|
)
|
||||||
|
@ -45,7 +45,7 @@ class SoftwareConfig(resource.Resource):
|
|||||||
#: produces.
|
#: produces.
|
||||||
outputs = resource.Body('outputs')
|
outputs = resource.Body('outputs')
|
||||||
|
|
||||||
def create(self, session, base_path=None):
|
def create(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# This overrides the default behavior of resource creation because
|
# This overrides the default behavior of resource creation because
|
||||||
# heat doesn't accept resource_key in its request.
|
# heat doesn't accept resource_key in its request.
|
||||||
return super().create(session, prepend_key=False, base_path=base_path)
|
return super().create(session, prepend_key, *args, **kwargs)
|
||||||
|
@ -49,12 +49,12 @@ class SoftwareDeployment(resource.Resource):
|
|||||||
#: The date and time when the software deployment resource was created.
|
#: The date and time when the software deployment resource was created.
|
||||||
updated_at = resource.Body('updated_time')
|
updated_at = resource.Body('updated_time')
|
||||||
|
|
||||||
def create(self, session, base_path=None):
|
def create(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# This overrides the default behavior of resource creation because
|
# This overrides the default behavior of resource creation because
|
||||||
# heat doesn't accept resource_key in its request.
|
# heat doesn't accept resource_key in its request.
|
||||||
return super().create(session, prepend_key=False, base_path=base_path)
|
return super().create(session, prepend_key, *args, **kwargs)
|
||||||
|
|
||||||
def commit(self, session, base_path=None):
|
def commit(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# This overrides the default behavior of resource creation because
|
# This overrides the default behavior of resource creation because
|
||||||
# heat doesn't accept resource_key in its request.
|
# heat doesn't accept resource_key in its request.
|
||||||
return super().commit(session, prepend_key=False, base_path=base_path)
|
return super().commit(session, prepend_key, *args, **kwargs)
|
||||||
|
@ -112,10 +112,10 @@ class Stack(resource.Resource):
|
|||||||
#: The ID of the user project created for this stack.
|
#: The ID of the user project created for this stack.
|
||||||
user_project_id = resource.Body('stack_user_project_id')
|
user_project_id = resource.Body('stack_user_project_id')
|
||||||
|
|
||||||
def create(self, session, base_path=None):
|
def create(self, session, prepend_key=False, *args, **kwargs):
|
||||||
# This overrides the default behavior of resource creation because
|
# This overrides the default behavior of resource creation because
|
||||||
# heat doesn't accept resource_key in its request.
|
# heat doesn't accept resource_key in its request.
|
||||||
return super().create(session, prepend_key=False, base_path=base_path)
|
return super().create(session, prepend_key, *args, **kwargs)
|
||||||
|
|
||||||
def commit(
|
def commit(
|
||||||
self,
|
self,
|
||||||
@ -219,7 +219,9 @@ class Stack(resource.Resource):
|
|||||||
base_path=None,
|
base_path=None,
|
||||||
error_message=None,
|
error_message=None,
|
||||||
skip_cache=False,
|
skip_cache=False,
|
||||||
|
*,
|
||||||
resolve_outputs=True,
|
resolve_outputs=True,
|
||||||
|
**params,
|
||||||
):
|
):
|
||||||
if not self.allow_fetch:
|
if not self.allow_fetch:
|
||||||
raise exceptions.MethodNotSupported(self, "fetch")
|
raise exceptions.MethodNotSupported(self, "fetch")
|
||||||
|
@ -33,7 +33,9 @@ class StackFiles(resource.Resource):
|
|||||||
# Backwards compat
|
# Backwards compat
|
||||||
stack_id = id # type: ignore
|
stack_id = id # type: ignore
|
||||||
|
|
||||||
def fetch(self, session, base_path=None):
|
def fetch(
|
||||||
|
self, session, requires_id=False, base_path=None, *args, **kwargs
|
||||||
|
):
|
||||||
# The stack files response contains a map of filenames and file
|
# The stack files response contains a map of filenames and file
|
||||||
# contents.
|
# contents.
|
||||||
request = self._prepare_request(requires_id=False, base_path=base_path)
|
request = self._prepare_request(requires_id=False, base_path=base_path)
|
||||||
|
@ -73,9 +73,10 @@ class ShareAccessRule(resource.Resource):
|
|||||||
url, json=body, headers=headers, microversion=microversion
|
url, json=body, headers=headers, microversion=microversion
|
||||||
)
|
)
|
||||||
|
|
||||||
def create(self, session, **kwargs):
|
def create(self, session, *args, **kwargs):
|
||||||
return super().create(
|
return super().create(
|
||||||
session,
|
session,
|
||||||
|
*args,
|
||||||
resource_request_key='allow_access',
|
resource_request_key='allow_access',
|
||||||
resource_response_key='access',
|
resource_response_key='access',
|
||||||
**kwargs,
|
**kwargs,
|
||||||
|
@ -55,7 +55,13 @@ class ShareNetworkSubnet(resource.Resource):
|
|||||||
#: Date and time the share network subnet was last updated at.
|
#: Date and time the share network subnet was last updated at.
|
||||||
updated_at = resource.Body("updated_at", type=str)
|
updated_at = resource.Body("updated_at", type=str)
|
||||||
|
|
||||||
def create(self, session, **kwargs):
|
def create(
|
||||||
|
self,
|
||||||
|
session,
|
||||||
|
*args,
|
||||||
|
resource_request_key='share-network-subnet',
|
||||||
|
**kwargs,
|
||||||
|
):
|
||||||
return super().create(
|
return super().create(
|
||||||
session, resource_request_key='share-network-subnet', **kwargs
|
session, resource_request_key=resource_request_key, *args, **kwargs
|
||||||
)
|
)
|
||||||
|
@ -498,10 +498,16 @@ class TestQuotaSet(TestVolumeProxy):
|
|||||||
'openstack.resource.Resource.fetch',
|
'openstack.resource.Resource.fetch',
|
||||||
self.proxy.get_quota_set,
|
self.proxy.get_quota_set,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'usage': False,
|
'usage': False,
|
||||||
},
|
},
|
||||||
method_result=quota_set.QuotaSet(),
|
method_result=quota_set.QuotaSet(),
|
||||||
@ -514,10 +520,16 @@ class TestQuotaSet(TestVolumeProxy):
|
|||||||
self.proxy.get_quota_set,
|
self.proxy.get_quota_set,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
method_kwargs={'usage': True, 'user_id': 'uid'},
|
method_kwargs={'usage': True, 'user_id': 'uid'},
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'usage': True,
|
'usage': True,
|
||||||
'user_id': 'uid',
|
'user_id': 'uid',
|
||||||
},
|
},
|
||||||
@ -528,11 +540,16 @@ class TestQuotaSet(TestVolumeProxy):
|
|||||||
'openstack.resource.Resource.fetch',
|
'openstack.resource.Resource.fetch',
|
||||||
self.proxy.get_quota_set_defaults,
|
self.proxy.get_quota_set_defaults,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
'/os-quota-sets/defaults',
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'base_path': '/os-quota-sets/defaults',
|
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -971,10 +971,16 @@ class TestQuotaSet(TestVolumeProxy):
|
|||||||
'openstack.resource.Resource.fetch',
|
'openstack.resource.Resource.fetch',
|
||||||
self.proxy.get_quota_set,
|
self.proxy.get_quota_set,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'usage': False,
|
'usage': False,
|
||||||
},
|
},
|
||||||
method_result=quota_set.QuotaSet(),
|
method_result=quota_set.QuotaSet(),
|
||||||
@ -987,10 +993,16 @@ class TestQuotaSet(TestVolumeProxy):
|
|||||||
self.proxy.get_quota_set,
|
self.proxy.get_quota_set,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
method_kwargs={'usage': True, 'user_id': 'uid'},
|
method_kwargs={'usage': True, 'user_id': 'uid'},
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'usage': True,
|
'usage': True,
|
||||||
'user_id': 'uid',
|
'user_id': 'uid',
|
||||||
},
|
},
|
||||||
@ -1001,11 +1013,16 @@ class TestQuotaSet(TestVolumeProxy):
|
|||||||
'openstack.resource.Resource.fetch',
|
'openstack.resource.Resource.fetch',
|
||||||
self.proxy.get_quota_set_defaults,
|
self.proxy.get_quota_set_defaults,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
'/os-quota-sets/defaults',
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'base_path': '/os-quota-sets/defaults',
|
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -1654,10 +1654,16 @@ class TestQuotaSet(TestComputeProxy):
|
|||||||
'openstack.resource.Resource.fetch',
|
'openstack.resource.Resource.fetch',
|
||||||
self.proxy.get_quota_set,
|
self.proxy.get_quota_set,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
},
|
},
|
||||||
method_result=quota_set.QuotaSet(),
|
method_result=quota_set.QuotaSet(),
|
||||||
expected_result=quota_set.QuotaSet(),
|
expected_result=quota_set.QuotaSet(),
|
||||||
@ -1669,12 +1675,17 @@ class TestQuotaSet(TestComputeProxy):
|
|||||||
self.proxy.get_quota_set,
|
self.proxy.get_quota_set,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
method_kwargs={'usage': True, 'user_id': 'uid'},
|
method_kwargs={'usage': True, 'user_id': 'uid'},
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
'/os-quota-sets/%(project_id)s/detail',
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'user_id': 'uid',
|
'user_id': 'uid',
|
||||||
'base_path': '/os-quota-sets/%(project_id)s/detail',
|
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -1683,11 +1694,16 @@ class TestQuotaSet(TestComputeProxy):
|
|||||||
'openstack.resource.Resource.fetch',
|
'openstack.resource.Resource.fetch',
|
||||||
self.proxy.get_quota_set_defaults,
|
self.proxy.get_quota_set_defaults,
|
||||||
method_args=['prj'],
|
method_args=['prj'],
|
||||||
expected_args=[self.proxy],
|
expected_args=[
|
||||||
|
self.proxy,
|
||||||
|
False,
|
||||||
|
'/os-quota-sets/%(project_id)s/defaults',
|
||||||
|
None,
|
||||||
|
False,
|
||||||
|
],
|
||||||
expected_kwargs={
|
expected_kwargs={
|
||||||
'error_message': None,
|
'microversion': None,
|
||||||
'requires_id': False,
|
'resource_response_key': None,
|
||||||
'base_path': '/os-quota-sets/%(project_id)s/defaults',
|
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -183,9 +183,7 @@ class TestStack(base.TestCase):
|
|||||||
|
|
||||||
res = sot.create(sess)
|
res = sot.create(sess)
|
||||||
|
|
||||||
mock_create.assert_called_once_with(
|
mock_create.assert_called_once_with(sess, False)
|
||||||
sess, prepend_key=False, base_path=None
|
|
||||||
)
|
|
||||||
self.assertEqual(mock_create.return_value, res)
|
self.assertEqual(mock_create.return_value, res)
|
||||||
|
|
||||||
def test_check(self):
|
def test_check(self):
|
||||||
|
@ -71,5 +71,11 @@ class CronTrigger(resource.Resource):
|
|||||||
#: The time at which the cron trigger was created
|
#: The time at which the cron trigger was created
|
||||||
updated_at = resource.Body("updated_at")
|
updated_at = resource.Body("updated_at")
|
||||||
|
|
||||||
def create(self, session, base_path=None):
|
def create(
|
||||||
return super().create(session, prepend_key=False, base_path=base_path)
|
self,
|
||||||
|
session,
|
||||||
|
prepend_key=False,
|
||||||
|
*args,
|
||||||
|
**kwargs,
|
||||||
|
):
|
||||||
|
return super().create(session, prepend_key, *args, **kwargs)
|
||||||
|
@ -58,7 +58,13 @@ class Execution(resource.Resource):
|
|||||||
#: The time at which the Execution was updated
|
#: The time at which the Execution was updated
|
||||||
updated_at = resource.Body("updated_at")
|
updated_at = resource.Body("updated_at")
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(
|
||||||
|
self,
|
||||||
|
session,
|
||||||
|
prepend_key=True,
|
||||||
|
base_path=None,
|
||||||
|
**kwargs,
|
||||||
|
):
|
||||||
request = self._prepare_request(
|
request = self._prepare_request(
|
||||||
requires_id=False, prepend_key=prepend_key, base_path=base_path
|
requires_id=False, prepend_key=prepend_key, base_path=base_path
|
||||||
)
|
)
|
||||||
|
@ -64,7 +64,13 @@ class Workflow(resource.Resource):
|
|||||||
request.headers.update(headers)
|
request.headers.update(headers)
|
||||||
return dict(url=uri, json=None, headers=request.headers, **kwargs)
|
return dict(url=uri, json=None, headers=request.headers, **kwargs)
|
||||||
|
|
||||||
def create(self, session, prepend_key=True, base_path=None):
|
def create(
|
||||||
|
self,
|
||||||
|
session,
|
||||||
|
prepend_key=True,
|
||||||
|
base_path=None,
|
||||||
|
**kwargs,
|
||||||
|
):
|
||||||
kwargs = self._request_kwargs(
|
kwargs = self._request_kwargs(
|
||||||
prepend_key=prepend_key, base_path=base_path
|
prepend_key=prepend_key, base_path=base_path
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user