Bump black to 23.3.0
I was using the distro-provided version of black, 22.8.0, during the blackify series. There's a newer version out however, 23.3.0. Bump this, applying the various changes it introduces in the process. Change-Id: I3442a7ddaf0cb35f37b84bdbe06625a28e982dba Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
This commit is contained in:
parent
c946294bdd
commit
c7010a2f92
@ -22,7 +22,7 @@ repos:
|
||||
hooks:
|
||||
- id: doc8
|
||||
- repo: https://github.com/psf/black
|
||||
rev: 22.8.0
|
||||
rev: 23.3.0
|
||||
hooks:
|
||||
- id: black
|
||||
args: ['-S', '-l', '79']
|
||||
|
@ -38,7 +38,6 @@ def download_image_stream(conn):
|
||||
# Read only 1024 bytes of memory at a time until
|
||||
# all of the image data has been consumed.
|
||||
for chunk in response.iter_content(chunk_size=1024):
|
||||
|
||||
# With each chunk, add it to the hash to be computed.
|
||||
md5.update(chunk)
|
||||
|
||||
|
@ -26,7 +26,6 @@ from openstack.workflow import workflow_service
|
||||
|
||||
|
||||
class ServicesMixin:
|
||||
|
||||
identity = identity_service.IdentityService(service_type='identity')
|
||||
|
||||
compute = compute_service.ComputeService(service_type='compute')
|
||||
|
@ -27,7 +27,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class Proxy(proxy.Proxy):
|
||||
|
||||
retriable_status_codes = _common.RETRIABLE_STATUS_CODES
|
||||
|
||||
_resource_registry = {
|
||||
|
@ -17,7 +17,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class Allocation(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'allocations'
|
||||
base_path = '/allocations'
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Chassis(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'chassis'
|
||||
base_path = '/chassis'
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Conductor(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'conductors'
|
||||
base_path = '/conductors'
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class DeployTemplate(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'deploy_templates'
|
||||
base_path = '/deploy_templates'
|
||||
|
||||
|
@ -17,7 +17,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class Driver(resource.Resource):
|
||||
|
||||
resources_key = 'drivers'
|
||||
base_path = '/drivers'
|
||||
|
||||
|
@ -71,7 +71,6 @@ class WaitResult(
|
||||
|
||||
|
||||
class Node(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'nodes'
|
||||
base_path = '/nodes'
|
||||
|
||||
@ -1323,7 +1322,6 @@ class Node(_common.ListMixin, resource.Resource):
|
||||
base_path=None,
|
||||
reset_interfaces=None,
|
||||
):
|
||||
|
||||
if reset_interfaces is not None:
|
||||
# The id cannot be dirty for an commit
|
||||
self._body._dirty.discard("id")
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Port(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'ports'
|
||||
base_path = '/ports'
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class PortGroup(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'portgroups'
|
||||
base_path = '/portgroups'
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class VolumeConnector(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'connectors'
|
||||
base_path = '/volume/connectors'
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class VolumeTarget(_common.ListMixin, resource.Resource):
|
||||
|
||||
resources_key = 'targets'
|
||||
base_path = '/volume/targets'
|
||||
|
||||
|
@ -21,7 +21,6 @@ _logger = _log.setup_logging('openstack')
|
||||
|
||||
|
||||
class Introspection(resource.Resource):
|
||||
|
||||
resources_key = 'introspection'
|
||||
base_path = '/introspection'
|
||||
|
||||
|
@ -22,7 +22,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Proxy(_base_proxy.BaseBlockStorageProxy):
|
||||
|
||||
# ====== SNAPSHOTS ======
|
||||
def get_snapshot(self, snapshot):
|
||||
"""Get a single snapshot
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class QuotaSet(quota_set.QuotaSet):
|
||||
|
||||
#: Properties
|
||||
#: The size (GB) of backups that are allowed for each project.
|
||||
backup_gigabytes = resource.Body('backup_gigabytes', type=int)
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class QuotaSet(quota_set.QuotaSet):
|
||||
|
||||
#: Properties
|
||||
#: The size (GB) of backups that are allowed for each project.
|
||||
backup_gigabytes = resource.Body('backup_gigabytes', type=int)
|
||||
|
@ -294,7 +294,6 @@ class BlockStorageCloudMixin:
|
||||
project_id = None
|
||||
error_msg = "Failed to get limits"
|
||||
if name_or_id:
|
||||
|
||||
proj = self.get_project(name_or_id)
|
||||
if not proj:
|
||||
raise exc.OpenStackCloudException("project does not exist")
|
||||
|
@ -432,7 +432,6 @@ class ComputeCloudMixin:
|
||||
params = {}
|
||||
project_id = None
|
||||
if name_or_id:
|
||||
|
||||
proj = self.get_project(name_or_id)
|
||||
if not proj:
|
||||
raise exc.OpenStackCloudException("project does not exist")
|
||||
@ -874,7 +873,7 @@ class ComputeCloudMixin:
|
||||
user_data = kwargs.pop('userdata')
|
||||
if user_data:
|
||||
kwargs['user_data'] = self._encode_server_userdata(user_data)
|
||||
for (desired, given) in (
|
||||
for desired, given in (
|
||||
('OS-DCF:diskConfig', 'disk_config'),
|
||||
('config_drive', 'config_drive'),
|
||||
('key_name', 'key_name'),
|
||||
@ -1092,7 +1091,6 @@ class ComputeCloudMixin:
|
||||
kwargs['block_device_mapping_v2'].append(block_mapping)
|
||||
kwargs['imageRef'] = ''
|
||||
elif boot_from_volume:
|
||||
|
||||
if isinstance(image, dict):
|
||||
image_obj = image
|
||||
else:
|
||||
|
@ -495,7 +495,6 @@ class FloatingIPCloudMixin:
|
||||
timeout=60,
|
||||
network_id=None,
|
||||
):
|
||||
|
||||
if not network_id:
|
||||
if network_name_or_id:
|
||||
try:
|
||||
@ -796,7 +795,6 @@ class FloatingIPCloudMixin:
|
||||
def _neutron_attach_ip_to_server(
|
||||
self, server, floating_ip, fixed_address=None, nat_destination=None
|
||||
):
|
||||
|
||||
# Find an available port
|
||||
(port, fixed_address) = self._nat_destination_port(
|
||||
server,
|
||||
@ -884,7 +882,6 @@ class FloatingIPCloudMixin:
|
||||
return True
|
||||
|
||||
def _nova_detach_ip_from_server(self, server_id, floating_ip_id):
|
||||
|
||||
f_ip = self.get_floating_ip(id=floating_ip_id)
|
||||
if f_ip is None:
|
||||
raise exc.OpenStackCloudException(
|
||||
|
@ -454,7 +454,6 @@ class IdentityCloudMixin:
|
||||
'name', 'enabled', 'type', 'service_type', 'description'
|
||||
)
|
||||
def update_service(self, name_or_id, **kwargs):
|
||||
|
||||
# NOTE(SamYaple): Keystone v3 only accepts 'type' but shade accepts
|
||||
# both 'type' and 'service_type' with a preference
|
||||
# towards 'type'
|
||||
|
@ -90,7 +90,6 @@ class NetworkCommonCloudMixin:
|
||||
return
|
||||
|
||||
for network in all_networks:
|
||||
|
||||
# External IPv4 networks
|
||||
if (
|
||||
network['name'] in self._external_ipv4_names
|
||||
|
@ -465,7 +465,6 @@ class SecurityGroupCloudMixin:
|
||||
# TODO(stephenfin): Remove this once we get rid of support for nova
|
||||
# secgroups
|
||||
def _normalize_secgroup(self, group):
|
||||
|
||||
ret = utils.Munch()
|
||||
# Copy incoming group because of shared dicts in unittests
|
||||
group = group.copy()
|
||||
@ -518,7 +517,6 @@ class SecurityGroupCloudMixin:
|
||||
# TODO(stephenfin): Remove this once we get rid of support for nova
|
||||
# secgroups
|
||||
def _normalize_secgroup_rule(self, rule):
|
||||
|
||||
ret = utils.Munch()
|
||||
# Copy incoming rule because of shared dicts in unittests
|
||||
rule = rule.copy()
|
||||
|
@ -23,7 +23,6 @@ __all__ = ['OpenStackInventory']
|
||||
|
||||
|
||||
class OpenStackInventory:
|
||||
|
||||
# Put this here so the capability can be detected with hasattr on the class
|
||||
extra_config = None
|
||||
|
||||
|
@ -27,7 +27,7 @@ def find_nova_interfaces(
|
||||
addresses, ext_tag=None, key_name=None, version=4, mac_addr=None
|
||||
):
|
||||
ret = []
|
||||
for (k, v) in iter(addresses.items()):
|
||||
for k, v in iter(addresses.items()):
|
||||
if key_name is not None and k != key_name:
|
||||
# key_name is specified and it doesn't match the current network.
|
||||
# Continue with the next one
|
||||
|
@ -75,7 +75,6 @@ class _OpenStackCloudMixin:
|
||||
_SHADE_OBJECT_AUTOCREATE_KEY = 'x-object-meta-x-shade-autocreated'
|
||||
|
||||
def __init__(self):
|
||||
|
||||
super(_OpenStackCloudMixin, self).__init__()
|
||||
|
||||
self.log = _log.setup_logging('openstack')
|
||||
|
@ -15,7 +15,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class MetadataMixin:
|
||||
|
||||
#: *Type: list of tag strings*
|
||||
metadata = resource.Body('metadata', type=dict)
|
||||
|
||||
|
@ -15,7 +15,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class TagMixin:
|
||||
|
||||
_tag_query_parameters = {
|
||||
'tags': 'tags',
|
||||
'any_tags': 'tags-any',
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class AbsoluteLimits(resource.Resource):
|
||||
|
||||
_max_microversion = '2.57'
|
||||
|
||||
#: The number of key-value pairs that can be set as image metadata.
|
||||
@ -74,7 +73,6 @@ class AbsoluteLimits(resource.Resource):
|
||||
|
||||
|
||||
class RateLimit(resource.Resource):
|
||||
|
||||
# TODO(mordred) Make a resource type for the contents of limit and add
|
||||
# it to list_type here.
|
||||
#: A list of the specific limits that apply to the ``regex`` and ``uri``.
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class ServerActionEvent(resource.Resource):
|
||||
|
||||
# Added the 'details' field in 2.84
|
||||
_max_microversion = '2.84'
|
||||
|
||||
|
@ -41,7 +41,6 @@ class ServerIP(resource.Resource):
|
||||
base_path=None,
|
||||
**params
|
||||
):
|
||||
|
||||
if base_path is None:
|
||||
base_path = cls.base_path
|
||||
|
||||
|
@ -36,7 +36,7 @@ def normalize_keys(config):
|
||||
def merge_clouds(old_dict, new_dict):
|
||||
"""Like dict.update, except handling nested dicts."""
|
||||
ret = old_dict.copy()
|
||||
for (k, v) in new_dict.items():
|
||||
for k, v in new_dict.items():
|
||||
if isinstance(v, dict):
|
||||
if k in ret:
|
||||
ret[k] = merge_clouds(ret[k], v)
|
||||
|
@ -101,7 +101,7 @@ def get_boolean(value):
|
||||
def _auth_update(old_dict, new_dict_source):
|
||||
"""Like dict.update, except handling the nested dict called auth."""
|
||||
new_dict = copy.deepcopy(new_dict_source)
|
||||
for (k, v) in new_dict.items():
|
||||
for k, v in new_dict.items():
|
||||
if k == 'auth':
|
||||
if k in old_dict:
|
||||
old_dict[k].update(v)
|
||||
@ -143,7 +143,6 @@ def _fix_argv(argv):
|
||||
|
||||
|
||||
class OpenStackConfig:
|
||||
|
||||
# These two attribute are to allow os-client-config to plumb in its
|
||||
# local versions for backwards compat.
|
||||
# They should not be used by anyone else.
|
||||
@ -949,7 +948,6 @@ class OpenStackConfig:
|
||||
return new_cloud
|
||||
|
||||
def get_all(self):
|
||||
|
||||
clouds = []
|
||||
|
||||
for cloud in self.get_cloud_names():
|
||||
@ -985,7 +983,7 @@ class OpenStackConfig:
|
||||
|
||||
os_args = dict()
|
||||
new_args = dict()
|
||||
for (key, val) in iter(args.items()):
|
||||
for key, val in iter(args.items()):
|
||||
if type(args[key]) == dict:
|
||||
# dive into the auth dict
|
||||
new_args[key] = self._fix_args(args[key])
|
||||
@ -1136,7 +1134,6 @@ class OpenStackConfig:
|
||||
return config
|
||||
|
||||
def _clean_up_after_ourselves(self, config, p_opt, winning_value):
|
||||
|
||||
# Clean up after ourselves
|
||||
for opt in [p_opt.name] + [o.name for o in p_opt.deprecated]:
|
||||
opt = opt.replace('-', '_')
|
||||
@ -1245,7 +1242,7 @@ class OpenStackConfig:
|
||||
|
||||
# Can't just do update, because None values take over
|
||||
for arg_list in region_args, args:
|
||||
for (key, val) in iter(arg_list.items()):
|
||||
for key, val in iter(arg_list.items()):
|
||||
if val is not None:
|
||||
if key == 'auth' and config[key] is not None:
|
||||
config[key] = _auth_update(config[key], val)
|
||||
@ -1268,7 +1265,7 @@ class OpenStackConfig:
|
||||
auth_plugin = None
|
||||
|
||||
# If any of the defaults reference other values, we need to expand
|
||||
for (key, value) in config.items():
|
||||
for key, value in config.items():
|
||||
if hasattr(value, 'format') and key not in FORMAT_EXCLUSIONS:
|
||||
config[key] = value.format(**config)
|
||||
|
||||
@ -1367,7 +1364,7 @@ class OpenStackConfig:
|
||||
|
||||
# Can't just do update, because None values take over
|
||||
for arg_list in region_args, args:
|
||||
for (key, val) in iter(arg_list.items()):
|
||||
for key, val in iter(arg_list.items()):
|
||||
if val is not None:
|
||||
if key == 'auth' and config[key] is not None:
|
||||
config[key] = _auth_update(config[key], val)
|
||||
@ -1389,7 +1386,7 @@ class OpenStackConfig:
|
||||
auth_plugin = None
|
||||
|
||||
# If any of the defaults reference other values, we need to expand
|
||||
for (key, value) in config.items():
|
||||
for key, value in config.items():
|
||||
if hasattr(value, 'format') and key not in FORMAT_EXCLUSIONS:
|
||||
config[key] = value.format(**config)
|
||||
|
||||
|
@ -26,7 +26,6 @@ from openstack import proxy
|
||||
|
||||
|
||||
class Proxy(proxy.Proxy):
|
||||
|
||||
_resource_registry = {
|
||||
"cluster": _cluster.Cluster,
|
||||
"cluster_template": _cluster_template.ClusterTemplate,
|
||||
|
@ -16,7 +16,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class Cluster(resource.Resource):
|
||||
|
||||
resources_key = 'clusters'
|
||||
base_path = '/clusters'
|
||||
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class ClusterCertificate(resource.Resource):
|
||||
|
||||
base_path = '/certificates'
|
||||
|
||||
# capabilities
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class ClusterTemplate(resource.Resource):
|
||||
|
||||
resources_key = 'clustertemplates'
|
||||
base_path = '/clustertemplates'
|
||||
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Service(resource.Resource):
|
||||
|
||||
resources_key = 'mservices'
|
||||
base_path = '/mservices'
|
||||
|
||||
|
@ -34,7 +34,6 @@ _ENDPOINT_TEMPLATES = {
|
||||
|
||||
|
||||
class ConnectionFixture(fixtures.Fixture):
|
||||
|
||||
_suffixes = {
|
||||
'baremetal': '/',
|
||||
'block-storage': '/{project_id}',
|
||||
|
@ -44,7 +44,6 @@ class Extension(resource.Resource):
|
||||
|
||||
@classmethod
|
||||
def list(cls, session, paginated=False, base_path=None, **params):
|
||||
|
||||
if base_path is None:
|
||||
base_path = cls.base_path
|
||||
|
||||
|
@ -28,7 +28,6 @@ class Version(resource.Resource):
|
||||
|
||||
@classmethod
|
||||
def list(cls, session, paginated=False, base_path=None, **params):
|
||||
|
||||
if base_path is None:
|
||||
base_path = cls.base_path
|
||||
|
||||
|
@ -49,7 +49,6 @@ def _get_name_and_filename(name, image_format):
|
||||
|
||||
|
||||
class Proxy(proxy.Proxy):
|
||||
|
||||
_resource_registry = {
|
||||
"cache": _cache.Cache,
|
||||
"image": _image.Image,
|
||||
|
@ -16,7 +16,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class BaseResource(resource.Resource):
|
||||
|
||||
commit_method = 'POST'
|
||||
create_method = 'PUT'
|
||||
|
||||
|
@ -447,7 +447,6 @@ class Proxy(proxy.Proxy):
|
||||
file_size = os.path.getsize(filename)
|
||||
|
||||
if self.is_object_stale(container_name, name, filename, md5, sha256):
|
||||
|
||||
self._connection.log.debug(
|
||||
"swift uploading %(filename)s to %(endpoint)s",
|
||||
{'filename': filename, 'endpoint': endpoint},
|
||||
@ -744,7 +743,7 @@ class Proxy(proxy.Proxy):
|
||||
def _get_file_segments(self, endpoint, filename, file_size, segment_size):
|
||||
# Use an ordered dict here so that testing can replicate things
|
||||
segments = collections.OrderedDict()
|
||||
for (index, offset) in enumerate(range(0, file_size, segment_size)):
|
||||
for index, offset in enumerate(range(0, file_size, segment_size)):
|
||||
remaining = file_size - (index * segment_size)
|
||||
segment = _utils.FileSegment(
|
||||
filename,
|
||||
|
@ -18,7 +18,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Info(resource.Resource):
|
||||
|
||||
base_path = "/info"
|
||||
|
||||
allow_fetch = True
|
||||
|
@ -31,7 +31,6 @@ def get_template_contents(
|
||||
files=None,
|
||||
existing=False,
|
||||
):
|
||||
|
||||
is_object = False
|
||||
tpl = None
|
||||
|
||||
@ -123,7 +122,6 @@ def get_file_contents(
|
||||
is_object=False,
|
||||
object_request=None,
|
||||
):
|
||||
|
||||
if recurse_if and recurse_if(from_data):
|
||||
if isinstance(from_data, dict):
|
||||
recurse_data = from_data.values()
|
||||
|
@ -187,7 +187,6 @@ class Stack(resource.Resource):
|
||||
skip_cache=False,
|
||||
resolve_outputs=True,
|
||||
):
|
||||
|
||||
if not self.allow_fetch:
|
||||
raise exceptions.MethodNotSupported(self, "fetch")
|
||||
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class StackEnvironment(resource.Resource):
|
||||
|
||||
base_path = "/stacks/%(stack_name)s/%(stack_id)s/environment"
|
||||
|
||||
# capabilities
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class StackFiles(resource.Resource):
|
||||
|
||||
base_path = "/stacks/%(stack_name)s/%(stack_id)s/files"
|
||||
|
||||
# capabilities
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class StackTemplate(resource.Resource):
|
||||
|
||||
base_path = "/stacks/%(stack_name)s/%(stack_id)s/template"
|
||||
|
||||
# capabilities
|
||||
|
@ -16,7 +16,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class Template(resource.Resource):
|
||||
|
||||
# capabilities
|
||||
allow_create = False
|
||||
allow_list = False
|
||||
|
@ -87,7 +87,6 @@ def _convert_type(value, data_type, list_type=None):
|
||||
|
||||
|
||||
class _BaseComponent:
|
||||
|
||||
# The name this component is being tracked as in the Resource
|
||||
key = None
|
||||
# The class to be used for mappings
|
||||
@ -2031,7 +2030,7 @@ class Resource(dict):
|
||||
)
|
||||
client_filters = dict()
|
||||
# Gather query parameters which are not supported by the server
|
||||
for (k, v) in params.items():
|
||||
for k, v in params.items():
|
||||
if (
|
||||
# Known attr
|
||||
hasattr(cls, k)
|
||||
|
@ -42,7 +42,6 @@ class _ServiceDisabledProxyShim:
|
||||
|
||||
|
||||
class ServiceDescription:
|
||||
|
||||
#: Dictionary of supported versions and proxy classes for that version
|
||||
supported_versions = None
|
||||
#: main service_type to use to find this service in the catalog
|
||||
@ -216,7 +215,6 @@ class ServiceDescription:
|
||||
)
|
||||
|
||||
if proxy_obj:
|
||||
|
||||
if getattr(proxy_obj, 'skip_discovery', False):
|
||||
# Some services, like swift, don't have discovery. While
|
||||
# keystoneauth will behave correctly and handle such
|
||||
|
@ -14,7 +14,6 @@ from openstack import resource
|
||||
|
||||
|
||||
class StoragePool(resource.Resource):
|
||||
|
||||
resources_key = "pools"
|
||||
base_path = "/scheduler-stats/pools"
|
||||
|
||||
|
@ -14,7 +14,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class BaseBaremetalTest(base.BaseFunctionalTest):
|
||||
|
||||
min_microversion = None
|
||||
node_id = None
|
||||
|
||||
|
@ -39,7 +39,6 @@ class Base(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestBareMetalAllocation(Base):
|
||||
|
||||
min_microversion = '1.52'
|
||||
|
||||
def test_allocation_create_get_delete(self):
|
||||
@ -135,7 +134,6 @@ class TestBareMetalAllocation(Base):
|
||||
|
||||
|
||||
class TestBareMetalAllocationUpdate(Base):
|
||||
|
||||
min_microversion = '1.57'
|
||||
|
||||
def test_allocation_update(self):
|
||||
|
@ -72,7 +72,6 @@ class TestBareMetalChassis(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestBareMetalChassisFields(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.8'
|
||||
|
||||
def test_chassis_fields(self):
|
||||
|
@ -15,7 +15,6 @@ from openstack.tests.functional.baremetal import base
|
||||
|
||||
|
||||
class TestBareMetalConductor(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.49'
|
||||
|
||||
def test_list_get_conductor(self):
|
||||
|
@ -15,7 +15,6 @@ from openstack.tests.functional.baremetal import base
|
||||
|
||||
|
||||
class TestBareMetalDeployTemplate(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.55'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -34,7 +34,6 @@ class TestBareMetalDriver(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestBareMetalDriverDetails(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.30'
|
||||
|
||||
def test_fake_hardware_get(self):
|
||||
|
@ -327,7 +327,6 @@ class TestBareMetalNode(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestNodeRetired(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.61'
|
||||
|
||||
def test_retired(self):
|
||||
@ -390,7 +389,6 @@ class TestNodeRetired(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestBareMetalNodeFields(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.8'
|
||||
|
||||
def test_node_fields(self):
|
||||
@ -404,7 +402,6 @@ class TestBareMetalNodeFields(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestBareMetalVif(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.28'
|
||||
|
||||
def setUp(self):
|
||||
@ -445,7 +442,6 @@ class TestBareMetalVif(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestTraits(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.37'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -132,7 +132,6 @@ class TestBareMetalPort(base.BaseBaremetalTest):
|
||||
|
||||
|
||||
class TestBareMetalPortFields(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.8'
|
||||
|
||||
def test_port_fields(self):
|
||||
|
@ -16,7 +16,6 @@ from openstack.tests.functional.baremetal import base
|
||||
|
||||
|
||||
class TestBareMetalPortGroup(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.23'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -16,7 +16,6 @@ from openstack.tests.functional.baremetal import base
|
||||
|
||||
|
||||
class TestBareMetalVolumeconnector(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.32'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -16,7 +16,6 @@ from openstack.tests.functional.baremetal import base
|
||||
|
||||
|
||||
class TestBareMetalVolumetarget(base.BaseBaremetalTest):
|
||||
|
||||
min_microversion = '1.32'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -41,7 +41,6 @@ def _disable_keep_alive(conn):
|
||||
|
||||
|
||||
class BaseFunctionalTest(base.TestCase):
|
||||
|
||||
_wait_for_timeout_key = ''
|
||||
|
||||
def setUp(self):
|
||||
|
@ -14,7 +14,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class BaseBlockStorageTest(base.BaseFunctionalTest):
|
||||
|
||||
_wait_for_timeout_key = 'OPENSTACKSDK_FUNC_TEST_TIMEOUT_BLOCK_STORAGE'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -14,7 +14,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class BaseBlockStorageTest(base.BaseFunctionalTest):
|
||||
|
||||
_wait_for_timeout_key = 'OPENSTACKSDK_FUNC_TEST_TIMEOUT_BLOCK_STORAGE'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -26,7 +26,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class TestDevstack(base.BaseFunctionalTest):
|
||||
|
||||
scenarios = [
|
||||
('designate', dict(env='DESIGNATE', service='dns')),
|
||||
('heat', dict(env='HEAT', service='orchestration')),
|
||||
|
@ -28,7 +28,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class TestEndpoints(base.KeystoneBaseFunctionalTest):
|
||||
|
||||
endpoint_attributes = [
|
||||
'id',
|
||||
'region',
|
||||
|
@ -119,7 +119,6 @@ class TestFloatingIP(base.BaseFunctionalTest):
|
||||
raise OpenStackCloudException('\n'.join(exception_list))
|
||||
|
||||
def _cleanup_ips(self, server):
|
||||
|
||||
exception_list = list()
|
||||
|
||||
fixed_ip = meta.get_server_private_ip(server)
|
||||
|
@ -22,7 +22,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class TestProjectCleanup(base.BaseFunctionalTest):
|
||||
|
||||
_wait_for_timeout_key = 'OPENSTACKSDK_FUNC_TEST_TIMEOUT_CLEANUP'
|
||||
|
||||
def setUp(self):
|
||||
|
@ -28,7 +28,6 @@ from openstack.tests.functional import base
|
||||
|
||||
|
||||
class TestServices(base.KeystoneBaseFunctionalTest):
|
||||
|
||||
service_attributes = ['id', 'name', 'type', 'description']
|
||||
|
||||
def setUp(self):
|
||||
|
@ -145,7 +145,6 @@ class TestStack(base.BaseFunctionalTest):
|
||||
self.assertEqual(12, len(new_rand))
|
||||
|
||||
def test_stack_nested(self):
|
||||
|
||||
test_template = tempfile.NamedTemporaryFile(
|
||||
suffix='.yaml', delete=False
|
||||
)
|
||||
|
@ -26,7 +26,6 @@ from openstack import utils
|
||||
|
||||
|
||||
class TestVolume(base.BaseFunctionalTest):
|
||||
|
||||
# Creating and deleting volumes is slow
|
||||
TIMEOUT_SCALING_FACTOR = 1.5
|
||||
|
||||
|
@ -18,7 +18,6 @@ from openstack.tests.functional.network.v2 import test_network
|
||||
|
||||
|
||||
class TestCluster(base.BaseFunctionalTest):
|
||||
|
||||
_wait_for_timeout_key = 'OPENSTACKSDK_FUNC_TEST_TIMEOUT_CLUSTER'
|
||||
|
||||
def setUp(self):
|
||||