Add docstrings for exceptions
Cleaning up a little technical debt by adding docstrings for our public APIs. Note: I plan to submit a patch per file as part of this bug work. These patches won't depend on each other. The last patch of the series will close the bug. Partial-Bug: #1614594 Change-Id: Ic0fdc5c77abcbb77a7ca08e4e00302a22ae8e4f5
This commit is contained in:
parent
761a9355ec
commit
52d4875c79
@ -51,68 +51,153 @@ class NeutronException(Exception):
|
||||
return self.msg
|
||||
|
||||
def use_fatal_exceptions(self):
|
||||
"""Is the instance using fatal exceptions.
|
||||
|
||||
:returns: Always returns False.
|
||||
"""
|
||||
return False
|
||||
|
||||
|
||||
class BadRequest(NeutronException):
|
||||
"""An exception indicating a generic bad request for a said resource.
|
||||
|
||||
A generic exception indicating a bad request for a specified resource.
|
||||
|
||||
:param resource: The resource requested.
|
||||
:param msg: A message indicating why the request is bad.
|
||||
"""
|
||||
message = _('Bad %(resource)s request: %(msg)s.')
|
||||
|
||||
|
||||
class NotFound(NeutronException):
|
||||
"""A generic not found exception."""
|
||||
pass
|
||||
|
||||
|
||||
class Conflict(NeutronException):
|
||||
"""A generic conflict exception."""
|
||||
pass
|
||||
|
||||
|
||||
class NotAuthorized(NeutronException):
|
||||
"""A generic not authorized exception."""
|
||||
message = _("Not authorized.")
|
||||
|
||||
|
||||
class ServiceUnavailable(NeutronException):
|
||||
"""A generic service unavailable exception."""
|
||||
message = _("The service is unavailable.")
|
||||
|
||||
|
||||
class AdminRequired(NotAuthorized):
|
||||
"""A not authorized exception indicating an admin is required.
|
||||
|
||||
A specialization of the NotAuthorized exception that indicates and admin
|
||||
is required to carry out the operation or access a resource.
|
||||
|
||||
:param reason: A message indicating additional details on why admin is
|
||||
required for the operation access.
|
||||
"""
|
||||
message = _("User does not have admin privileges: %(reason)s.")
|
||||
|
||||
|
||||
class ObjectNotFound(NotFound):
|
||||
"""A not found exception indicating an identifiable object isn't found.
|
||||
|
||||
A specialization of the NotFound exception indicating an object with a said
|
||||
ID doesn't exist.
|
||||
|
||||
:param id: The ID of the (not found) object.
|
||||
"""
|
||||
message = _("Object %(id)s not found.")
|
||||
|
||||
|
||||
class NetworkNotFound(NotFound):
|
||||
"""An exception indicating a network was not found.
|
||||
|
||||
A specialization of the NotFound exception indicating a requested network
|
||||
could not be found.
|
||||
|
||||
:param net_id: The UUID of the (not found) network requested.
|
||||
"""
|
||||
message = _("Network %(net_id)s could not be found.")
|
||||
|
||||
|
||||
class SubnetNotFound(NotFound):
|
||||
"""An exception for a requested subnet that's not found.
|
||||
|
||||
A specialization of the NotFound exception indicating a requested subnet
|
||||
could not be found.
|
||||
|
||||
:param subnet_id: The UUID of the (not found) subnet that was requested.
|
||||
"""
|
||||
message = _("Subnet %(subnet_id)s could not be found.")
|
||||
|
||||
|
||||
class PortNotFound(NotFound):
|
||||
"""An exception for a requested port that's not found.
|
||||
|
||||
A specialization of the NotFound exception indicating a requested port
|
||||
could not be found.
|
||||
|
||||
:param port_id: The UUID of the (not found) port that was requested.
|
||||
"""
|
||||
message = _("Port %(port_id)s could not be found.")
|
||||
|
||||
|
||||
class PortNotFoundOnNetwork(NotFound):
|
||||
"""An exception for a requested port on a network that's not found.
|
||||
|
||||
A specialization of the NotFound exception that indicates a specified
|
||||
port on a specified network doesn't exist.
|
||||
|
||||
:param port_id: The UUID of the (not found) port that was requested.
|
||||
:param net_id: The UUID of the network that was requested for the port.
|
||||
"""
|
||||
message = _("Port %(port_id)s could not be found "
|
||||
"on network %(net_id)s.")
|
||||
|
||||
|
||||
class DeviceNotFoundError(NotFound):
|
||||
"""An exception for a requested device that's not found.
|
||||
|
||||
A specialization of the NotFound exception indicating a requested device
|
||||
could not be found.
|
||||
|
||||
:param device_name: The name of the (not found) device that was requested.
|
||||
"""
|
||||
message = _("Device '%(device_name)s' does not exist.")
|
||||
|
||||
|
||||
class InUse(NeutronException):
|
||||
"""A generic exception indicating a resource is already in use."""
|
||||
message = _("The resource is in use.")
|
||||
|
||||
|
||||
class NetworkInUse(InUse):
|
||||
"""An operational error indicating the network still has ports in use.
|
||||
|
||||
A specialization of the InUse exception indicating a network operation was
|
||||
requested, but failed because there are still ports in use on the said
|
||||
network.
|
||||
|
||||
:param net_id: The UUID of the network requested.
|
||||
"""
|
||||
message = _("Unable to complete operation on network %(net_id)s. "
|
||||
"There are one or more ports still in use on the network.")
|
||||
|
||||
|
||||
class SubnetInUse(InUse):
|
||||
"""An operational error indicating a subnet is still in use.
|
||||
|
||||
A specialization of the InUse exception indicating an operation failed
|
||||
on a subnet because the subnet is still in use.
|
||||
|
||||
:param subnet_id: The UUID of the subnet requested.
|
||||
:param reason: Details on why the operation failed. If None, a default
|
||||
reason is used indicating one or more ports still have IP allocations
|
||||
on the subnet.
|
||||
"""
|
||||
message = _("Unable to complete operation on subnet %(subnet_id)s: "
|
||||
"%(reason)s.")
|
||||
|
||||
@ -124,6 +209,15 @@ class SubnetInUse(InUse):
|
||||
|
||||
|
||||
class SubnetPoolInUse(InUse):
|
||||
"""An operational error indicating a subnet pool is still in use.
|
||||
|
||||
A specialization of the InUse exception indicating an operation failed
|
||||
on a subnet pool because it's still in use.
|
||||
|
||||
:param subnet_pool_id: The UUID of the subnet pool requested.
|
||||
:param reason: Details on why the operation failed. If None a default
|
||||
reason is used indicating two or more concurrent subnets are allocated.
|
||||
"""
|
||||
message = _("Unable to complete operation on subnet pool "
|
||||
"%(subnet_pool_id)s. %(reason)s.")
|
||||
|
||||
@ -134,108 +228,248 @@ class SubnetPoolInUse(InUse):
|
||||
|
||||
|
||||
class PortInUse(InUse):
|
||||
"""An operational error indicating a requested port is already attached.
|
||||
|
||||
A specialization of the InUse exception indicating an operation failed on
|
||||
a port because it already has an attached device.
|
||||
|
||||
:param port_id: The UUID of the port requested.
|
||||
:param net_id: The UUID of the requested port's network.
|
||||
:param device_id: The UUID of the device already attached to the port.
|
||||
"""
|
||||
message = _("Unable to complete operation on port %(port_id)s "
|
||||
"for network %(net_id)s. Port already has an attached "
|
||||
"device %(device_id)s.")
|
||||
|
||||
|
||||
class ServicePortInUse(InUse):
|
||||
"""An error indicating a service port can't be deleted.
|
||||
|
||||
A specialization of the InUse exception indicating a requested service
|
||||
port can't be deleted via the APIs.
|
||||
|
||||
:param port_id: The UUID of the port requested.
|
||||
:param reason: Details on why the operation failed.
|
||||
"""
|
||||
message = _("Port %(port_id)s cannot be deleted directly via the "
|
||||
"port API: %(reason)s.")
|
||||
|
||||
|
||||
class PortBound(InUse):
|
||||
"""An operational error indicating a port is already bound.
|
||||
|
||||
A specialization of the InUse exception indicating an operation can't
|
||||
complete because the port is already bound.
|
||||
|
||||
:param port_id: The UUID of the port requested.
|
||||
:param vif_type: The VIF type associated with the bound port.
|
||||
:param old_mac: The old MAC address of the port.
|
||||
:param net_mac: The new MAC address of the port.
|
||||
"""
|
||||
message = _("Unable to complete operation on port %(port_id)s, "
|
||||
"port is already bound, port type: %(vif_type)s, "
|
||||
"old_mac %(old_mac)s, new_mac %(new_mac)s.")
|
||||
|
||||
|
||||
class MacAddressInUse(InUse):
|
||||
"""An network operational error indicating a MAC address is already in use.
|
||||
|
||||
A specialization of the InUse exception indicating an operation failed
|
||||
on a network because a specified MAC address is already in use on that
|
||||
network.
|
||||
|
||||
:param net_id: The UUID of the network.
|
||||
:param mac: The requested MAC address that's already in use.
|
||||
"""
|
||||
message = _("Unable to complete operation for network %(net_id)s. "
|
||||
"The mac address %(mac)s is in use.")
|
||||
|
||||
|
||||
class InvalidIpForNetwork(BadRequest):
|
||||
"""An exception indicating an invalid IP was specified for a network.
|
||||
|
||||
A specialization of the BadRequest exception indicating a specified IP
|
||||
address is invalid for a network.
|
||||
|
||||
:param ip_address: The IP address that's invalid on the network.
|
||||
"""
|
||||
message = _("IP address %(ip_address)s is not a valid IP "
|
||||
"for any of the subnets on the specified network.")
|
||||
|
||||
|
||||
class InvalidIpForSubnet(BadRequest):
|
||||
"""An exception indicating an invalid IP was specified for a subnet.
|
||||
|
||||
A specialization of the BadRequest exception indicating a specified IP
|
||||
address is invalid for a subnet.
|
||||
|
||||
:param ip_address: The IP address that's invalid on the subnet.
|
||||
"""
|
||||
message = _("IP address %(ip_address)s is not a valid IP "
|
||||
"for the specified subnet.")
|
||||
|
||||
|
||||
class IpAddressInUse(InUse):
|
||||
"""An network operational error indicating an IP address is already in use.
|
||||
|
||||
A specialization of the InUse exception indicating an operation can't
|
||||
complete because an IP address is in use.
|
||||
|
||||
:param net_id: The UUID of the network.
|
||||
:param ip_address: The IP address that's already in use on the network.
|
||||
"""
|
||||
message = _("Unable to complete operation for network %(net_id)s. "
|
||||
"The IP address %(ip_address)s is in use.")
|
||||
|
||||
|
||||
class VlanIdInUse(InUse):
|
||||
"""An exception indicating VLAN creation failed because it's already in use.
|
||||
|
||||
A specialization of the InUse exception indicating network creation failed
|
||||
because a specified VLAN is already in use on the physical network.
|
||||
|
||||
:param vlan_id: The LVAN ID.
|
||||
:param physical_network: The physical network.
|
||||
"""
|
||||
message = _("Unable to create the network. "
|
||||
"The VLAN %(vlan_id)s on physical network "
|
||||
"%(physical_network)s is in use.")
|
||||
|
||||
|
||||
class TunnelIdInUse(InUse):
|
||||
"""A network creation failure due to tunnel ID already in use.
|
||||
|
||||
A specialization of the InUse exception indicating network creation failed
|
||||
because a said tunnel ID is already in use.
|
||||
|
||||
:param tunnel_id: The ID of the tunnel that's areadly in use.
|
||||
"""
|
||||
message = _("Unable to create the network. "
|
||||
"The tunnel ID %(tunnel_id)s is in use.")
|
||||
|
||||
|
||||
class ResourceExhausted(ServiceUnavailable):
|
||||
"""A service uavailable error indicating a resource is exhausted."""
|
||||
pass
|
||||
|
||||
|
||||
class NoNetworkAvailable(ResourceExhausted):
|
||||
"""A failure to create a network due to no tenant networks for allocation.
|
||||
|
||||
A specialization of the ResourceExhausted exception indicating network
|
||||
creation failed because no tenant network are available for allocation.
|
||||
"""
|
||||
message = _("Unable to create the network. "
|
||||
"No tenant network is available for allocation.")
|
||||
|
||||
|
||||
class SubnetMismatchForPort(BadRequest):
|
||||
"""A bad request error indicating a specified subnet isn't on a port.
|
||||
|
||||
A specialization of the BadRequest exception indicating a subnet on a port
|
||||
doesn't match a specified subnet.
|
||||
|
||||
:param port_id: The UUID of the port.
|
||||
:param subnet_id: The UUID of the requested subnet.
|
||||
"""
|
||||
message = _("Subnet on port %(port_id)s does not match "
|
||||
"the requested subnet %(subnet_id)s.")
|
||||
|
||||
|
||||
class Invalid(NeutronException):
|
||||
"""A generic base class for invalid errors."""
|
||||
def __init__(self, message=None):
|
||||
self.message = message
|
||||
super(Invalid, self).__init__()
|
||||
|
||||
|
||||
class InvalidInput(BadRequest):
|
||||
"""A bad request due to invalid input.
|
||||
|
||||
A specialization of the BadRequest error indicating bad input was
|
||||
specified.
|
||||
|
||||
:param error_message: Details on the operation that failed due to bad
|
||||
input.
|
||||
"""
|
||||
message = _("Invalid input for operation: %(error_message)s.")
|
||||
|
||||
|
||||
class IpAddressGenerationFailure(Conflict):
|
||||
"""A conflict error due to no more IP addresses on a said network.
|
||||
|
||||
:param net_id: The UUID of the network that has no more IP addresses.
|
||||
"""
|
||||
message = _("No more IP addresses available on network %(net_id)s.")
|
||||
|
||||
|
||||
class PreexistingDeviceFailure(NeutronException):
|
||||
"""A creation error due to an already existing device.
|
||||
|
||||
An exception indication creation failed due to an already existing
|
||||
device.
|
||||
|
||||
:param dev_name: The device name that already exists.
|
||||
"""
|
||||
message = _("Creation failed. %(dev_name)s already exists.")
|
||||
|
||||
|
||||
class OverQuota(Conflict):
|
||||
"""A error due to exceeding quota limits.
|
||||
|
||||
A specialization of the Conflict exception indicating quota has been
|
||||
exceeded.
|
||||
|
||||
:param overs: The resources that have exceeded quota.
|
||||
"""
|
||||
message = _("Quota exceeded for resources: %(overs)s.")
|
||||
|
||||
|
||||
class InvalidContentType(NeutronException):
|
||||
"""An error due to invalid content type.
|
||||
|
||||
:param content_type: The invalid content type.
|
||||
"""
|
||||
message = _("Invalid content type %(content_type)s.")
|
||||
|
||||
|
||||
class ExternalIpAddressExhausted(BadRequest):
|
||||
"""An error due to not finding IP addresses on an external network.
|
||||
|
||||
A specialization of the BadRequest exception indicating no IP addresses
|
||||
can be found on a network.
|
||||
|
||||
:param net_id: The UUID of the network.
|
||||
"""
|
||||
message = _("Unable to find any IP address on external "
|
||||
"network %(net_id)s.")
|
||||
|
||||
|
||||
class TooManyExternalNetworks(NeutronException):
|
||||
"""An error due to more than one external networks existing."""
|
||||
message = _("More than one external network exists.")
|
||||
|
||||
|
||||
class InvalidConfigurationOption(NeutronException):
|
||||
"""An error due to an invalid configuration option value.
|
||||
|
||||
:param opt_name: The name of the configuration option that has an invalid
|
||||
value.
|
||||
:param opt_value: The value that's invalid for the configuration option.
|
||||
"""
|
||||
message = _("An invalid value was provided for %(opt_name)s: "
|
||||
"%(opt_value)s.")
|
||||
|
||||
|
||||
class NetworkTunnelRangeError(NeutronException):
|
||||
"""An error due to an invalid network tunnel range.
|
||||
|
||||
An exception indicating an invalid netowrk tunnel range was specified.
|
||||
|
||||
:param tunnel_range: The invalid tunnel range. If specified in the
|
||||
start:end' format, they will be converted automatically.
|
||||
:param error: Additional details on why the range is invalid.
|
||||
"""
|
||||
message = _("Invalid network tunnel range: "
|
||||
"'%(tunnel_range)s' - %(error)s.")
|
||||
|
||||
@ -247,10 +481,20 @@ class NetworkTunnelRangeError(NeutronException):
|
||||
|
||||
|
||||
class PolicyInitError(NeutronException):
|
||||
"""An error due to policy initialization failure.
|
||||
|
||||
:param policy: The policy that failed to initialize.
|
||||
:param reason: Details on why the policy failed to initialize.
|
||||
"""
|
||||
message = _("Failed to initialize policy %(policy)s because %(reason)s.")
|
||||
|
||||
|
||||
class PolicyCheckError(NeutronException):
|
||||
"""An error due to a policy check failure.
|
||||
|
||||
:param policy: The policy that failed to check.
|
||||
:param reason: Additional details on the failure.
|
||||
"""
|
||||
message = _("Failed to check policy %(policy)s because %(reason)s.")
|
||||
|
||||
|
||||
@ -263,5 +507,11 @@ class MultipleExceptions(Exception):
|
||||
"""
|
||||
|
||||
def __init__(self, exceptions, *args, **kwargs):
|
||||
"""Create a new instance wrapping the exceptions.
|
||||
|
||||
:param exceptions: The inner exceptions this instance is composed of.
|
||||
:param args: Passed onto parent constructor.
|
||||
:param kwargs: Passed onto parent constructor.
|
||||
"""
|
||||
super(MultipleExceptions, self).__init__(*args, **kwargs)
|
||||
self.inner_exceptions = exceptions
|
||||
|
Loading…
Reference in New Issue
Block a user