Fix the reST field raises in docstrings

Probably the most common format for documenting arguments is reST field
lists [1]. This change updates some docstrings to comply with the field
lists syntax.

[1] http://sphinx-doc.org/domains.html#info-field-lists

Change-Id: I0c35c6b4df840018534737bca2ca32dc977b0e05
This commit is contained in:
liuyamin 2017-06-27 16:05:10 +08:00
parent 2d18ecdf4b
commit 1eeb354c27
19 changed files with 43 additions and 43 deletions

@ -303,7 +303,7 @@ def print_obj_metadata(metadata):
:param metadata: dict of object metadata :param metadata: dict of object metadata
:raises: ValueError :raises ValueError:
""" """
user_metadata = {} user_metadata = {}
sys_metadata = {} sys_metadata = {}

@ -195,7 +195,7 @@ def parse_scenario(scenario_data):
for feeding to run_scenario(). for feeding to run_scenario().
:returns: scenario :returns: scenario
:raises: ValueError on invalid scenario :raises ValueError: on invalid scenario
""" """
parsed_scenario = {} parsed_scenario = {}

@ -277,7 +277,7 @@ def valid_timestamp(request):
:param request: the swob request object :param request: the swob request object
:returns: a valid Timestamp instance :returns: a valid Timestamp instance
:raises: HTTPBadRequest on missing or invalid X-Timestamp :raises HTTPBadRequest: on missing or invalid X-Timestamp
""" """
try: try:
return request.timestamp return request.timestamp
@ -364,7 +364,7 @@ def check_name_format(req, name, target_type):
:param name: header value to validate :param name: header value to validate
:param target_type: which header is being validated (Account or Container) :param target_type: which header is being validated (Account or Container)
:returns: A properly encoded account name or container name :returns: A properly encoded account name or container name
:raise: HTTPPreconditionFailed if account header :raise HTTPPreconditionFailed: if account header
is not well formatted. is not well formatted.
""" """
if not name: if not name:

@ -738,7 +738,7 @@ class DatabaseBroker(object):
Validates that metadata falls within acceptable limits. Validates that metadata falls within acceptable limits.
:param metadata: to be validated :param metadata: to be validated
:raises: HTTPBadRequest if MAX_META_COUNT or MAX_META_OVERALL_SIZE :raises HTTPBadRequest: if MAX_META_COUNT or MAX_META_OVERALL_SIZE
is exceeded, or if metadata contains non-UTF-8 data is exceeded, or if metadata contains non-UTF-8 data
""" """
meta_count = 0 meta_count = 0

@ -296,7 +296,7 @@ class Bulk(object):
Checks if the container exists and if not try to create it. Checks if the container exists and if not try to create it.
:params container_path: an unquoted path to a container to be created :params container_path: an unquoted path to a container to be created
:returns: True if created container, False if container exists :returns: True if created container, False if container exists
:raises: CreateContainerError when unable to create container :raises CreateContainerError: when unable to create container
""" """
new_env = req.environ.copy() new_env = req.environ.copy()
new_env['PATH_INFO'] = container_path new_env['PATH_INFO'] = container_path
@ -324,7 +324,7 @@ class Bulk(object):
Will populate objs_to_delete with data from request input. Will populate objs_to_delete with data from request input.
:params req: a Swob request :params req: a Swob request
:returns: a list of the contents of req.body when separated by newline. :returns: a list of the contents of req.body when separated by newline.
:raises: HTTPException on failures :raises HTTPException: on failures
""" """
line = '' line = ''
data_remaining = True data_remaining = True

@ -156,7 +156,7 @@ def _check_path_header(req, name, length, error_msg):
:param length: length of path segment check :param length: length of path segment check
:param error_msg: error message for client :param error_msg: error message for client
:returns: A tuple with path parts according to length :returns: A tuple with path parts according to length
:raise: HTTPPreconditionFailed if header value :raise HTTPPreconditionFailed: if header value
is not well formatted. is not well formatted.
""" """
src_header = unquote(req.headers.get(name)) src_header = unquote(req.headers.get(name))
@ -178,7 +178,7 @@ def _check_copy_from_header(req):
:param req: HTTP request object :param req: HTTP request object
:returns: A tuple with container name and object name :returns: A tuple with container name and object name
:raise: HTTPPreconditionFailed if x-copy-from value :raise HTTPPreconditionFailed: if x-copy-from value
is not well formatted. is not well formatted.
""" """
return _check_path_header(req, 'X-Copy-From', 2, return _check_path_header(req, 'X-Copy-From', 2,
@ -194,7 +194,7 @@ def _check_destination_header(req):
:param req: HTTP request object :param req: HTTP request object
:returns: A tuple with container name and object name :returns: A tuple with container name and object name
:raise: HTTPPreconditionFailed if destination value :raise HTTPPreconditionFailed: if destination value
is not well formatted. is not well formatted.
""" """
return _check_path_header(req, 'Destination', 2, return _check_path_header(req, 'Destination', 2,

@ -53,7 +53,7 @@ class Crypto(object):
:param key: 256-bit key :param key: 256-bit key
:param iv: 128-bit iv or nonce used for encryption :param iv: 128-bit iv or nonce used for encryption
:raises: ValueError on invalid key or iv :raises ValueError: on invalid key or iv
:returns: an instance of an encryptor :returns: an instance of an encryptor
""" """
self.check_key(key) self.check_key(key)

@ -151,7 +151,7 @@ class ListEndpointsMiddleware(object):
:returns: parsed path parts as a tuple with version filled in as :returns: parsed path parts as a tuple with version filled in as
configured default response version if not specified. configured default response version if not specified.
:raises: ValueError if path is invalid, message will say why. :raises ValueError: if path is invalid, message will say why.
""" """
clean_path = request.path[len(self.endpoints_path) - 1:] clean_path = request.path[len(self.endpoints_path) - 1:]
# try to peel off version # try to peel off version

@ -189,7 +189,7 @@ class RateLimitMiddleware(object):
:param key: a memcache key :param key: a memcache key
:param max_rate: maximum rate allowed in requests per second :param max_rate: maximum rate allowed in requests per second
:raises: MaxSleepTimeHitError if max sleep time is exceeded. :raises MaxSleepTimeHitError: if max sleep time is exceeded.
""" """
try: try:
now_m = int(round(time.time() * self.clock_accuracy)) now_m = int(round(time.time() * self.clock_accuracy))

@ -311,7 +311,7 @@ def parse_and_validate_input(req_body, req_path):
corresponding swob.Range object. If d_in does not have a key corresponding swob.Range object. If d_in does not have a key
'range', neither will d_out. 'range', neither will d_out.
:raises: HTTPException on parse errors or semantic errors (e.g. bogus :raises HTTPException: on parse errors or semantic errors (e.g. bogus
JSON structure, syntactically invalid ranges) JSON structure, syntactically invalid ranges)
:returns: a list of dictionaries on success :returns: a list of dictionaries on success
@ -899,7 +899,7 @@ class StaticLargeObject(object):
concatenation of the segments. concatenation of the segments.
:params req: a swob.Request with a path referencing an object :params req: a swob.Request with a path referencing an object
:raises: HttpException on errors :raises HttpException: on errors
""" """
return SloGetContext(self).handle_slo_get_or_head(req, start_response) return SloGetContext(self).handle_slo_get_or_head(req, start_response)
@ -911,7 +911,7 @@ class StaticLargeObject(object):
call self and start_response and returns a WSGI iterator. call self and start_response and returns a WSGI iterator.
:params req: a swob.Request with an obj in path :params req: a swob.Request with an obj in path
:raises: HttpException on errors :raises HttpException: on errors
""" """
try: try:
vrs, account, container, obj = req.split_path(1, 4, True) vrs, account, container, obj = req.split_path(1, 4, True)

@ -57,7 +57,7 @@ def get_param(req, name, default=None):
:param default: result to return if the parameter is not found :param default: result to return if the parameter is not found
:returns: HTTP request parameter value :returns: HTTP request parameter value
(as UTF-8 encoded str, not unicode object) (as UTF-8 encoded str, not unicode object)
:raises: HTTPBadRequest if param not valid UTF-8 byte sequence :raises HTTPBadRequest: if param not valid UTF-8 byte sequence
""" """
value = req.params.get(name, default) value = req.params.get(name, default)
if value and not isinstance(value, six.text_type): if value and not isinstance(value, six.text_type):
@ -77,8 +77,8 @@ def get_listing_content_type(req):
:param req: request object :param req: request object
:returns: content type as a string (e.g. text/plain, application/json) :returns: content type as a string (e.g. text/plain, application/json)
:raises: HTTPNotAcceptable if the requested content type is not acceptable :raises HTTPNotAcceptable: if the requested content type is not acceptable
:raises: HTTPBadRequest if the 'format' query param is provided and :raises HTTPBadRequest: if the 'format' query param is provided and
not valid UTF-8 not valid UTF-8
""" """
query_format = get_param(req, 'format') query_format = get_param(req, 'format')
@ -103,7 +103,7 @@ def get_name_and_placement(request, minsegs=1, maxsegs=None,
:returns: a list, result of :meth:`split_and_validate_path` with :returns: a list, result of :meth:`split_and_validate_path` with
the BaseStoragePolicy instance appended on the end the BaseStoragePolicy instance appended on the end
:raises: HTTPServiceUnavailable if the path is invalid or no policy exists :raises HTTPServiceUnavailable: if the path is invalid or no policy exists
with the extracted policy_index. with the extracted policy_index.
""" """
policy_index = request.headers.get('X-Backend-Storage-Policy-Index') policy_index = request.headers.get('X-Backend-Storage-Policy-Index')
@ -126,7 +126,7 @@ def split_and_validate_path(request, minsegs=1, maxsegs=None,
:returns: result of :meth:`~swift.common.utils.split_path` if :returns: result of :meth:`~swift.common.utils.split_path` if
everything's okay everything's okay
:raises: HTTPBadRequest if something's not okay :raises HTTPBadRequest: if something's not okay
""" """
try: try:
segs = split_path(unquote(request.path), segs = split_path(unquote(request.path),

@ -167,7 +167,7 @@ class Ring(object):
:param ring_name: ring name string (basically specified from policy) :param ring_name: ring name string (basically specified from policy)
:param validation_hook: hook point to validate ring configuration ontime :param validation_hook: hook point to validate ring configuration ontime
:raises: RingLoadError if the loaded ring data violates its constraint :raises RingLoadError: if the loaded ring data violates its constraint
""" """
def __init__(self, serialized_path, reload_time=15, ring_name=None, def __init__(self, serialized_path, reload_time=15, ring_name=None,

@ -426,7 +426,7 @@ def parse_add_value(add_value):
:returns: dictionary with keys 'region', 'zone', 'ip', 'port', 'device', :returns: dictionary with keys 'region', 'zone', 'ip', 'port', 'device',
'replication_ip', 'replication_port', 'meta' 'replication_ip', 'replication_port', 'meta'
:raises: ValueError if add_value is malformed :raises ValueError: if add_value is malformed
""" """
region = None region = None
rest = add_value rest = add_value

@ -111,7 +111,7 @@ def get_policy_string(base, policy_or_index):
storage Policy-0 is assumed. storage Policy-0 is assumed.
:returns: base name with policy index added :returns: base name with policy index added
:raises: PolicyError if no policy exists with the given policy_index :raises PolicyError: if no policy exists with the given policy_index
""" """
if isinstance(policy_or_index, BaseStoragePolicy): if isinstance(policy_or_index, BaseStoragePolicy):
policy = policy_or_index policy = policy_or_index
@ -130,7 +130,7 @@ def split_policy_string(policy_string):
:param policy_string: base name with policy index added :param policy_string: base name with policy index added
:raises: PolicyError if given index does not map to a valid policy :raises PolicyError: if given index does not map to a valid policy
:returns: a tuple, in the form (base, policy) where base is the base :returns: a tuple, in the form (base, policy) where base is the base
string and policy is the StoragePolicy instance for the string and policy is the StoragePolicy instance for the
index encoded in the policy_string. index encoded in the policy_string.
@ -288,7 +288,7 @@ class BaseStoragePolicy(object):
to check policy names before setting them. to check policy names before setting them.
:param name: a name string for a single policy name. :param name: a name string for a single policy name.
:raises: PolicyError if the policy name is invalid. :raises PolicyError: if the policy name is invalid.
""" """
if not name: if not name:
raise PolicyError('Invalid name %r' % name, self.idx) raise PolicyError('Invalid name %r' % name, self.idx)

@ -1029,7 +1029,7 @@ class Request(object):
trailing data, raises ValueError. trailing data, raises ValueError.
:returns: list of segments with a length of maxsegs (non-existent :returns: list of segments with a length of maxsegs (non-existent
segments will return as None) segments will return as None)
:raises: ValueError if given an invalid path :raises ValueError: if given an invalid path
""" """
return split_path( return split_path(
self.environ.get('SCRIPT_NAME', '') + self.environ['PATH_INFO'], self.environ.get('SCRIPT_NAME', '') + self.environ['PATH_INFO'],

@ -1276,7 +1276,7 @@ def split_path(path, minsegs=1, maxsegs=None, rest_with_last=False):
trailing data, raises ValueError. trailing data, raises ValueError.
:returns: list of segments with a length of maxsegs (non-existent :returns: list of segments with a length of maxsegs (non-existent
segments will return as None) segments will return as None)
:raises: ValueError if given an invalid path :raises ValueError: if given an invalid path
""" """
if not maxsegs: if not maxsegs:
maxsegs = minsegs maxsegs = minsegs
@ -1311,7 +1311,7 @@ def validate_device_partition(device, partition):
:param device: device to validate :param device: device to validate
:param partition: partition to validate :param partition: partition to validate
:raises: ValueError if given an invalid device or partition :raises ValueError: if given an invalid device or partition
""" """
if not device or '/' in device or device in ['.', '..']: if not device or '/' in device or device in ['.', '..']:
raise ValueError('Invalid device: %s' % quote(device or '')) raise ValueError('Invalid device: %s' % quote(device or ''))
@ -2943,7 +2943,7 @@ def affinity_key_function(affinity_str):
:param affinity_str: affinity config value, e.g. "r1z2=3" :param affinity_str: affinity config value, e.g. "r1z2=3"
or "r1=1, r2z1=2, r2z2=2" or "r1=1, r2z1=2, r2z2=2"
:returns: single-argument function :returns: single-argument function
:raises: ValueError if argument invalid :raises ValueError: if argument invalid
""" """
affinity_str = affinity_str.strip() affinity_str = affinity_str.strip()
@ -2996,7 +2996,7 @@ def affinity_locality_predicate(write_affinity_str):
:param write_affinity_str: affinity config value, e.g. "r1z2" :param write_affinity_str: affinity config value, e.g. "r1z2"
or "r1, r2z1, r2z2" or "r1, r2z1, r2z2"
:returns: single-argument function, or None if affinity_str is empty :returns: single-argument function, or None if affinity_str is empty
:raises: ValueError if argument invalid :raises ValueError: if argument invalid
""" """
affinity_str = write_affinity_str.strip() affinity_str = write_affinity_str.strip()
@ -3634,7 +3634,7 @@ def parse_content_range(content_range):
:param content_range: Content-Range header value to parse, :param content_range: Content-Range header value to parse,
e.g. "bytes 100-1249/49004" e.g. "bytes 100-1249/49004"
:returns: 3-tuple (start, end, total) :returns: 3-tuple (start, end, total)
:raises: ValueError if malformed :raises ValueError: if malformed
""" """
found = re.search(_content_range_pattern, content_range) found = re.search(_content_range_pattern, content_range)
if not found: if not found:
@ -3816,7 +3816,7 @@ def iter_multipart_mime_documents(wsgi_input, boundary, read_chunk_size=4096):
:param boundary: The mime boundary to separate new file-like :param boundary: The mime boundary to separate new file-like
objects on. objects on.
:returns: A generator of file-like objects for each part. :returns: A generator of file-like objects for each part.
:raises: MimeInvalid if the document is malformed :raises MimeInvalid: if the document is malformed
""" """
boundary = '--' + boundary boundary = '--' + boundary
blen = len(boundary) + 2 # \r\n blen = len(boundary) + 2 # \r\n

@ -140,7 +140,7 @@ class ContainerController(BaseStorageServer):
Validate that the index supplied maps to a policy. Validate that the index supplied maps to a policy.
:returns: policy index from request, or None if not present :returns: policy index from request, or None if not present
:raises: HTTPBadRequest if the supplied index is bogus :raises HTTPBadRequest: if the supplied index is bogus
""" """
policy_index = req.headers.get('X-Backend-Storage-Policy-Index', None) policy_index = req.headers.get('X-Backend-Storage-Policy-Index', None)

@ -950,7 +950,7 @@ class ECAppIter(object):
can also use it in the body. can also use it in the body.
:returns: None :returns: None
:raises: HTTPException on error :raises HTTPException: on error
""" """
self.mime_boundary = resp.boundary self.mime_boundary = resp.boundary
@ -1468,7 +1468,7 @@ class Putter(object):
:param informational: if True then try to get a 100-continue response, :param informational: if True then try to get a 100-continue response,
otherwise try to get a final response. otherwise try to get a final response.
:returns: HTTPResponse :returns: HTTPResponse
:raises: Timeout if the response took too long :raises Timeout: if the response took too long
""" """
# don't do this update of self.resp if the Expect response during # don't do this update of self.resp if the Expect response during
# connect() was actually a final response # connect() was actually a final response
@ -1587,10 +1587,10 @@ class Putter(object):
:returns: Putter instance :returns: Putter instance
:raises: ConnectionTimeout if initial connection timed out :raises ConnectionTimeout: if initial connection timed out
:raises: ResponseTimeout if header retrieval timed out :raises ResponseTimeout: if header retrieval timed out
:raises: InsufficientStorage on 507 response from node :raises InsufficientStorage: on 507 response from node
:raises: PutterConnectError on non-507 server error response from node :raises PutterConnectError: on non-507 server error response from node
""" """
conn, expect_resp, final_resp, connect_duration = cls._make_connection( conn, expect_resp, final_resp, connect_duration = cls._make_connection(
node, part, path, headers, conn_timeout, node_timeout) node, part, path, headers, conn_timeout, node_timeout)
@ -1700,9 +1700,9 @@ class MIMEPutter(Putter):
:param need_multiphase: if True then multiphase support is required of :param need_multiphase: if True then multiphase support is required of
the object server the object server
:raises: FooterNotSupported if need_metadata_footer is set but :raises FooterNotSupported: if need_metadata_footer is set but
backend node can't process footers backend node can't process footers
:raises: MultiphasePUTNotSupported if need_multiphase is set but :raises MultiphasePUTNotSupported: if need_multiphase is set but
backend node can't handle multiphase PUT backend node can't handle multiphase PUT
""" """
mime_boundary = "%.64x" % random.randint(0, 16 ** 64) mime_boundary = "%.64x" % random.randint(0, 16 ** 64)

@ -363,7 +363,7 @@ class Application(object):
:param req: the request :param req: the request
:returns: tuple of (controller class, path dictionary) :returns: tuple of (controller class, path dictionary)
:raises: ValueError (thrown by split_path) if given invalid path :raises ValueError: (thrown by split_path) if given invalid path
""" """
if req.path == '/info': if req.path == '/info':
d = dict(version=None, d = dict(version=None,