Remove Python 2.6 format style

In Python 2.6 it was required to use {0}, {1}...{n} when using the
string format function. In Python 2.7 and Python 3 it it not required.

Change {N} to {} in code.

This brings the code in style alignment with other projects like
ironic and ironic-lib.

Change-Id: I81c4bb67b0974f73905f14b589b3dd0a7131650d
Depends-On: I8f0e5405f3e2d6e35418c73f610ac6b779dd75e5
This commit is contained in:
John L. Villalovos 2016-10-05 11:35:29 -07:00
parent bf3c4fb38c
commit 20d960ff98
8 changed files with 91 additions and 91 deletions

View File

@ -117,7 +117,7 @@ class IronicPythonAgentHeartbeater(threading.Thread):
self.min_jitter_multiplier, self.min_jitter_multiplier,
self.max_jitter_multiplier) self.max_jitter_multiplier)
interval = self.agent.heartbeat_timeout * interval_multiplier interval = self.agent.heartbeat_timeout * interval_multiplier
log_msg = 'sleeping before next heartbeat, interval: {0}' log_msg = 'sleeping before next heartbeat, interval: {}'
LOG.info(log_msg.format(interval)) LOG.info(log_msg.format(interval))
finally: finally:
os.close(self.reader) os.close(self.reader)

View File

@ -87,7 +87,7 @@ class InvalidCommandParamsError(InvalidContentError):
class RequestedObjectNotFoundError(NotFound): class RequestedObjectNotFoundError(NotFound):
def __init__(self, type_descr, obj_id): def __init__(self, type_descr, obj_id):
details = '{0} with id {1} not found.'.format(type_descr, obj_id) details = '{} with id {} not found.'.format(type_descr, obj_id)
super(RequestedObjectNotFoundError, self).__init__(details) super(RequestedObjectNotFoundError, self).__init__(details)
@ -142,7 +142,7 @@ class ImageDownloadError(RESTError):
message = 'Error downloading image' message = 'Error downloading image'
def __init__(self, image_id, msg): def __init__(self, image_id, msg):
details = 'Download of image id {0} failed: {1}'.format(image_id, msg) details = 'Download of image id {} failed: {}'.format(image_id, msg)
super(ImageDownloadError, self).__init__(details) super(ImageDownloadError, self).__init__(details)
@ -150,9 +150,9 @@ class ImageChecksumError(RESTError):
"""Error raised when an image fails to verify against its checksum.""" """Error raised when an image fails to verify against its checksum."""
message = 'Error verifying image checksum' message = 'Error verifying image checksum'
details_str = ('Image failed to verify against checksum. location: {0}; ' details_str = ('Image failed to verify against checksum. location: {}; '
'image ID: {1}; image checksum: {2}; verification ' 'image ID: {}; image checksum: {}; verification '
'checksum: {3}') 'checksum: {}')
def __init__(self, image_id, image_location, checksum, def __init__(self, image_id, image_location, checksum,
calculated_checksum): calculated_checksum):
@ -167,8 +167,8 @@ class ImageWriteError(RESTError):
message = 'Error writing image to device' message = 'Error writing image to device'
def __init__(self, device, exit_code, stdout, stderr): def __init__(self, device, exit_code, stdout, stderr):
details = ('Writing image to device {0} failed with exit code ' details = ('Writing image to device {} failed with exit code '
'{1}. stdout: {2}. stderr: {3}') '{}. stdout: {}. stderr: {}')
details = details.format(device, exit_code, stdout, stderr) details = details.format(device, exit_code, stdout, stderr)
super(ImageWriteError, self).__init__(details) super(ImageWriteError, self).__init__(details)
@ -179,7 +179,7 @@ class ConfigDriveTooLargeError(RESTError):
message = 'Configdrive is too large for intended partition' message = 'Configdrive is too large for intended partition'
def __init__(self, filename, filesize): def __init__(self, filename, filesize):
details = ('Configdrive at {0} has size {1}, which is larger than ' details = ('Configdrive at {} has size {}, which is larger than '
'the intended partition.').format(filename, filesize) 'the intended partition.').format(filename, filesize)
super(ConfigDriveTooLargeError, self).__init__(details) super(ConfigDriveTooLargeError, self).__init__(details)
@ -190,8 +190,8 @@ class ConfigDriveWriteError(RESTError):
message = 'Error writing configdrive to device' message = 'Error writing configdrive to device'
def __init__(self, device, exit_code, stdout, stderr): def __init__(self, device, exit_code, stdout, stderr):
details = ('Writing configdrive to device {0} failed with exit code ' details = ('Writing configdrive to device {} failed with exit code '
'{1}. stdout: {2}. stderr: {3}.') '{}. stdout: {}. stderr: {}.')
details = details.format(device, exit_code, stdout, stderr) details = details.format(device, exit_code, stdout, stderr)
super(ConfigDriveWriteError, self).__init__(details) super(ConfigDriveWriteError, self).__init__(details)
@ -202,8 +202,8 @@ class SystemRebootError(RESTError):
message = 'Error rebooting system' message = 'Error rebooting system'
def __init__(self, exit_code, stdout, stderr): def __init__(self, exit_code, stdout, stderr):
details = ('Reboot script failed with exit code {0}. stdout: ' details = ('Reboot script failed with exit code {}. stdout: '
'{1}. stderr: {2}.') '{}. stderr: {}.')
details = details.format(exit_code, stdout, stderr) details = details.format(exit_code, stdout, stderr)
super(SystemRebootError, self).__init__(details) super(SystemRebootError, self).__init__(details)
@ -263,7 +263,7 @@ class HardwareManagerMethodNotFound(RESTError):
message = 'No HardwareManager found to handle method' message = 'No HardwareManager found to handle method'
def __init__(self, method): def __init__(self, method):
details = 'Could not find method: {0}'.format(method) details = 'Could not find method: {}'.format(method)
super(HardwareManagerMethodNotFound, self).__init__(details) super(HardwareManagerMethodNotFound, self).__init__(details)
@ -291,7 +291,7 @@ class CleanVersionMismatch(RESTError):
def __init__(self, agent_version, node_version): def __init__(self, agent_version, node_version):
self.status_code = 409 self.status_code = 409
details = ('Agent clean version: {0}, node clean version: {1}' details = ('Agent clean version: {}, node clean version: {}'
.format(agent_version, node_version)) .format(agent_version, node_version))
super(CleanVersionMismatch, self).__init__(details) super(CleanVersionMismatch, self).__init__(details)
@ -311,7 +311,7 @@ class ISCSIError(RESTError):
message = 'Error starting iSCSI target' message = 'Error starting iSCSI target'
def __init__(self, error_msg): def __init__(self, error_msg):
details = 'Error starting iSCSI target: {0}'.format(error_msg) details = 'Error starting iSCSI target: {}'.format(error_msg)
super(ISCSIError, self).__init__(details) super(ISCSIError, self).__init__(details)
@ -319,7 +319,7 @@ class ISCSICommandError(ISCSIError):
"""Error executing TGT command.""" """Error executing TGT command."""
def __init__(self, error_msg, exit_code, stdout, stderr): def __init__(self, error_msg, exit_code, stdout, stderr):
details = ('{0}. Failed with exit code {1}. stdout: {2}. stderr: {3}') details = ('{}. Failed with exit code {}. stdout: {}. stderr: {}')
details = details.format(error_msg, exit_code, stdout, stderr) details = details.format(error_msg, exit_code, stdout, stderr)
super(ISCSICommandError, self).__init__(details) super(ISCSICommandError, self).__init__(details)

View File

@ -119,7 +119,7 @@ class AsyncCommandResult(BaseCommandResult):
self.execute_method = execute_method self.execute_method = execute_method
self.command_state_lock = threading.Lock() self.command_state_lock = threading.Lock()
thread_name = 'agent-command-{0}'.format(self.id) thread_name = 'agent-command-{}'.format(self.id)
self.execution_thread = threading.Thread(target=self.run, self.execution_thread = threading.Thread(target=self.run,
name=thread_name) name=thread_name)
@ -200,14 +200,14 @@ class BaseAgentExtension(object):
cmd = self.command_map.get(command_name) cmd = self.command_map.get(command_name)
if cmd is None: if cmd is None:
raise errors.InvalidCommandError( raise errors.InvalidCommandError(
'Unknown command: {0}'.format(command_name)) 'Unknown command: {}'.format(command_name))
return cmd(**kwargs) return cmd(**kwargs)
def check_cmd_presence(self, ext_obj, ext, cmd): def check_cmd_presence(self, ext_obj, ext, cmd):
if not (hasattr(ext_obj, 'execute') and hasattr(ext_obj, 'command_map') if not (hasattr(ext_obj, 'execute') and hasattr(ext_obj, 'command_map')
and cmd in ext_obj.command_map): and cmd in ext_obj.command_map):
raise errors.InvalidCommandParamsError( raise errors.InvalidCommandParamsError(
"Extension {0} doesn't provide {1} method".format(ext, cmd)) "Extension {} doesn't provide {} method".format(ext, cmd))
class ExecuteCommandMixin(object): class ExecuteCommandMixin(object):

View File

@ -94,14 +94,14 @@ def _start_lio(iqn, portal_port, device):
rtslib_fb.LUN(tpg, storage_object=storage, lun=1) rtslib_fb.LUN(tpg, storage_object=storage, lun=1)
tpg.enable = 1 tpg.enable = 1
except rtslib_fb.utils.RTSLibError as exc: except rtslib_fb.utils.RTSLibError as exc:
msg = 'Failed to create a target: {0}'.format(exc) msg = 'Failed to create a target: {}'.format(exc)
raise errors.ISCSIError(msg) raise errors.ISCSIError(msg)
try: try:
# bind to the default port on all interfaces # bind to the default port on all interfaces
rtslib_fb.NetworkPortal(tpg, '0.0.0.0', portal_port) rtslib_fb.NetworkPortal(tpg, '0.0.0.0', portal_port)
except rtslib_fb.utils.RTSLibError as exc: except rtslib_fb.utils.RTSLibError as exc:
msg = 'Failed to publish a target: {0}'.format(exc) msg = 'Failed to publish a target: {}'.format(exc)
raise errors.ISCSIError(msg) raise errors.ISCSIError(msg)

View File

@ -48,7 +48,7 @@ def _image_location(image_info):
:param image_info: Image information dictionary. :param image_info: Image information dictionary.
:returns: The full, absolute path to the image as a string. :returns: The full, absolute path to the image as a string.
""" """
return '/tmp/{0}'.format(image_info['id']) return '/tmp/{}'.format(image_info['id'])
def _path_to_script(script): def _path_to_script(script):
@ -83,8 +83,8 @@ def _write_partition_image(image, image_info, device):
root_mb = image_info['root_mb'] root_mb = image_info['root_mb']
if image_mb > int(root_mb): if image_mb > int(root_mb):
msg = ('Root partition is too small for requested image. Image ' msg = ('Root partition is too small for requested image. Image '
'virtual size: {0} MB, Root size: {1} MB').format(image_mb, 'virtual size: {} MB, Root size: {} MB').format(image_mb,
root_mb) root_mb)
raise errors.InvalidCommandParamsError(msg) raise errors.InvalidCommandParamsError(msg)
try: try:
return disk_utils.work_on_disk(device, root_mb, return disk_utils.work_on_disk(device, root_mb,
@ -115,7 +115,7 @@ def _write_whole_disk_image(image, image_info, device):
""" """
script = _path_to_script('shell/write_image.sh') script = _path_to_script('shell/write_image.sh')
command = ['/bin/bash', script, image, device] command = ['/bin/bash', script, image, device]
LOG.info('Writing image with command: {0}'.format(' '.join(command))) LOG.info('Writing image with command: {}'.format(' '.join(command)))
try: try:
stdout, stderr = utils.execute(*command, check_exit_code=[0]) stdout, stderr = utils.execute(*command, check_exit_code=[0])
except processutils.ProcessExecutionError as e: except processutils.ProcessExecutionError as e:
@ -139,7 +139,7 @@ def _write_image(image_info, device):
else: else:
_write_whole_disk_image(image, image_info, device) _write_whole_disk_image(image, image_info, device)
totaltime = time.time() - starttime totaltime = time.time() - starttime
LOG.info('Image {0} written to device {1} in {2} seconds'.format( LOG.info('Image {} written to device {} in {} seconds'.format(
image, device, totaltime)) image, device, totaltime))
return uuids return uuids
@ -173,7 +173,7 @@ def _write_configdrive_to_file(configdrive, filename):
:param configdrive: Contents of the configdrive file. :param configdrive: Contents of the configdrive file.
:param filename: The filename of where to write the configdrive. :param filename: The filename of where to write the configdrive.
""" """
LOG.debug('Writing configdrive to {0}'.format(filename)) LOG.debug('Writing configdrive to {}'.format(filename))
# configdrive data is base64'd, decode it first # configdrive data is base64'd, decode it first
data = six.StringIO(base64.b64decode(configdrive)) data = six.StringIO(base64.b64decode(configdrive))
gunzipped = gzip.GzipFile('configdrive', 'rb', 9, data) gunzipped = gzip.GzipFile('configdrive', 'rb', 9, data)
@ -208,7 +208,7 @@ def _write_configdrive_to_partition(configdrive, device):
starttime = time.time() starttime = time.time()
script = _path_to_script('shell/copy_configdrive_to_disk.sh') script = _path_to_script('shell/copy_configdrive_to_disk.sh')
command = ['/bin/bash', script, filename, device] command = ['/bin/bash', script, filename, device]
LOG.info('copying configdrive to disk with command {0}'.format( LOG.info('copying configdrive to disk with command {}'.format(
' '.join(command))) ' '.join(command)))
try: try:
@ -220,7 +220,7 @@ def _write_configdrive_to_partition(configdrive, device):
e.stderr) e.stderr)
totaltime = time.time() - starttime totaltime = time.time() - starttime
LOG.info('configdrive copied from {0} to {1} in {2} seconds'.format( LOG.info('configdrive copied from {} to {} in {} seconds'.format(
filename, filename,
device, device,
totaltime)) totaltime))
@ -236,12 +236,12 @@ def _message_format(msg, image_info, device, partition_uuids):
partition_uuids.get('efi system partition uuid')) partition_uuids.get('efi system partition uuid'))
if (image_info.get('deploy_boot_mode') == 'uefi' and if (image_info.get('deploy_boot_mode') == 'uefi' and
image_info.get('boot_option') == 'local'): image_info.get('boot_option') == 'local'):
result_msg = msg + 'root_uuid={2} efi_system_partition_uuid={3}' result_msg = msg + 'root_uuid={} efi_system_partition_uuid={}'
message = result_msg.format(image_info['id'], device, message = result_msg.format(image_info['id'], device,
root_uuid, root_uuid,
efi_system_partition_uuid) efi_system_partition_uuid)
else: else:
result_msg = msg + 'root_uuid={2}' result_msg = msg + 'root_uuid={}'
message = result_msg.format(image_info['id'], device, root_uuid) message = result_msg.format(image_info['id'], device, root_uuid)
else: else:
message = result_msg.format(image_info['id'], device) message = result_msg.format(image_info['id'], device)
@ -280,12 +280,12 @@ class ImageDownload(object):
details = [] details = []
for url in image_info['urls']: for url in image_info['urls']:
try: try:
LOG.info("Attempting to download image from {0}".format(url)) LOG.info("Attempting to download image from {}".format(url))
self._request = self._download_file(image_info, url) self._request = self._download_file(image_info, url)
except errors.ImageDownloadError as e: except errors.ImageDownloadError as e:
failtime = time.time() - self._time failtime = time.time() - self._time
log_msg = ('URL: {0}; time: {1} ' log_msg = ('URL: {}; time: {} '
'seconds. Error: {2}').format( 'seconds. Error: {}').format(
url, failtime, e.details) url, failtime, e.details)
LOG.warning('Image download failed. %s', log_msg) LOG.warning('Image download failed. %s', log_msg)
details += log_msg details += log_msg
@ -313,8 +313,8 @@ class ImageDownload(object):
proxies = image_info.get('proxies', {}) proxies = image_info.get('proxies', {})
resp = requests.get(url, stream=True, proxies=proxies) resp = requests.get(url, stream=True, proxies=proxies)
if resp.status_code != 200: if resp.status_code != 200:
msg = ('Received status code {0} from {1}, expected 200. Response ' msg = ('Received status code {} from {}, expected 200. Response '
'body: {2}').format(resp.status_code, url, resp.text) 'body: {}').format(resp.status_code, url, resp.text)
raise errors.ImageDownloadError(image_info['id'], msg) raise errors.ImageDownloadError(image_info['id'], msg)
return resp return resp
@ -352,8 +352,8 @@ def _verify_image(image_info, image_location, checksum):
:raises: ImageChecksumError if the checksum of the local image does not :raises: ImageChecksumError if the checksum of the local image does not
match the checksum as reported by glance in image_info. match the checksum as reported by glance in image_info.
""" """
LOG.debug('Verifying image at {0} against MD5 checksum ' LOG.debug('Verifying image at {} against MD5 checksum '
'{1}'.format(image_location, checksum)) '{}'.format(image_location, checksum))
if checksum != image_info['checksum']: if checksum != image_info['checksum']:
LOG.error(errors.ImageChecksumError.details_str.format( LOG.error(errors.ImageChecksumError.details_str.format(
image_location, image_info['id'], image_location, image_info['id'],
@ -379,13 +379,13 @@ def _download_image(image_info):
for chunk in image_download: for chunk in image_download:
f.write(chunk) f.write(chunk)
except Exception as e: except Exception as e:
msg = 'Unable to write image to {0}. Error: {1}'.format( msg = 'Unable to write image to {}. Error: {}'.format(
image_location, str(e)) image_location, str(e))
raise errors.ImageDownloadError(image_info['id'], msg) raise errors.ImageDownloadError(image_info['id'], msg)
totaltime = time.time() - starttime totaltime = time.time() - starttime
LOG.info("Image downloaded from {0} in {1} seconds".format(image_location, LOG.info("Image downloaded from {} in {} seconds".format(image_location,
totaltime)) totaltime))
_verify_image(image_info, image_location, image_download.md5sum()) _verify_image(image_info, image_location, image_download.md5sum())
@ -405,7 +405,7 @@ def _validate_image_info(ext, image_info=None, **kwargs):
for field in ['id', 'urls', 'checksum']: for field in ['id', 'urls', 'checksum']:
if field not in image_info: if field not in image_info:
msg = 'Image is missing \'{0}\' field.'.format(field) msg = 'Image is missing \'{}\' field.'.format(field)
raise errors.InvalidCommandParamsError(msg) raise errors.InvalidCommandParamsError(msg)
if type(image_info['urls']) != list or not image_info['urls']: if type(image_info['urls']) != list or not image_info['urls']:
@ -465,12 +465,12 @@ class StandbyExtension(base.BaseAgentExtension):
for chunk in image_download: for chunk in image_download:
f.write(chunk) f.write(chunk)
except Exception as e: except Exception as e:
msg = 'Unable to write image to device {0}. Error: {1}'.format( msg = 'Unable to write image to device {}. Error: {}'.format(
device, str(e)) device, str(e))
raise errors.ImageDownloadError(image_info['id'], msg) raise errors.ImageDownloadError(image_info['id'], msg)
totaltime = time.time() - starttime totaltime = time.time() - starttime
LOG.info("Image streamed onto device {0} in {1} " LOG.info("Image streamed onto device {} in {} "
"seconds".format(device, totaltime)) "seconds".format(device, totaltime))
# Verify if the checksum of the streamed image is correct # Verify if the checksum of the streamed image is correct
_verify_image(image_info, device, image_download.md5sum()) _verify_image(image_info, device, image_download.md5sum())
@ -492,13 +492,13 @@ class StandbyExtension(base.BaseAgentExtension):
LOG.debug('Caching image %s', image_info['id']) LOG.debug('Caching image %s', image_info['id'])
device = hardware.dispatch_to_managers('get_os_install_device') device = hardware.dispatch_to_managers('get_os_install_device')
msg = 'image ({0}) already present on device {1} ' msg = 'image ({}) already present on device {} '
if self.cached_image_id != image_info['id'] or force: if self.cached_image_id != image_info['id'] or force:
LOG.debug('Already had %s cached, overwriting', LOG.debug('Already had %s cached, overwriting',
self.cached_image_id) self.cached_image_id)
self._cache_and_write_image(image_info, device) self._cache_and_write_image(image_info, device)
msg = 'image ({0}) cached to device {1} ' msg = 'image ({}) cached to device {} '
result_msg = _message_format(msg, image_info, device, result_msg = _message_format(msg, image_info, device,
self.partition_uuids) self.partition_uuids)
@ -553,7 +553,7 @@ class StandbyExtension(base.BaseAgentExtension):
if configdrive is not None: if configdrive is not None:
_write_configdrive_to_partition(configdrive, device) _write_configdrive_to_partition(configdrive, device)
msg = 'image ({0}) written to device {1} ' msg = 'image ({}) written to device {} '
result_msg = _message_format(msg, image_info, device, result_msg = _message_format(msg, image_info, device,
self.partition_uuids) self.partition_uuids)
LOG.info(result_msg) LOG.info(result_msg)

View File

@ -57,7 +57,7 @@ def _get_device_info(dev, devclass, field):
return f.read().strip() return f.read().strip()
except IOError: except IOError:
LOG.warning( LOG.warning(
"Can't find field {0} for device {1} in device class {2}".format( "Can't find field {} for device {} in device class {}".format(
field, dev, devclass)) field, dev, devclass))
@ -498,8 +498,8 @@ class GenericHardwareManager(HardwareManager):
return self.lldp_data.get(interface_name) return self.lldp_data.get(interface_name)
def _get_interface_info(self, interface_name): def _get_interface_info(self, interface_name):
addr_path = '{0}/class/net/{1}/address'.format(self.sys_path, addr_path = '{}/class/net/{}/address'.format(self.sys_path,
interface_name) interface_name)
with open(addr_path) as addr_file: with open(addr_path) as addr_file:
mac_addr = addr_file.read().strip() mac_addr = addr_file.read().strip()
@ -520,8 +520,8 @@ class GenericHardwareManager(HardwareManager):
return None return None
def _interface_has_carrier(self, interface_name): def _interface_has_carrier(self, interface_name):
path = '{0}/class/net/{1}/carrier'.format(self.sys_path, path = '{}/class/net/{}/carrier'.format(self.sys_path,
interface_name) interface_name)
try: try:
with open(path, 'rt') as fp: with open(path, 'rt') as fp:
return fp.read().strip() == '1' return fp.read().strip() == '1'
@ -531,12 +531,12 @@ class GenericHardwareManager(HardwareManager):
return False return False
def _is_device(self, interface_name): def _is_device(self, interface_name):
device_path = '{0}/class/net/{1}/device'.format(self.sys_path, device_path = '{}/class/net/{}/device'.format(self.sys_path,
interface_name) interface_name)
return os.path.exists(device_path) return os.path.exists(device_path)
def list_network_interfaces(self): def list_network_interfaces(self):
iface_names = os.listdir('{0}/class/net'.format(self.sys_path)) iface_names = os.listdir('{}/class/net'.format(self.sys_path))
iface_names = [name for name in iface_names if self._is_device(name)] iface_names = [name for name in iface_names if self._is_device(name)]
if CONF.collect_lldp: if CONF.collect_lldp:
@ -749,7 +749,7 @@ class GenericHardwareManager(HardwareManager):
if self._shred_block_device(node, block_device): if self._shred_block_device(node, block_device):
return return
msg = ('Unable to erase block device {0}: device is unsupported.' msg = ('Unable to erase block device {}: device is unsupported.'
).format(block_device.name) ).format(block_device.name)
LOG.error(msg) LOG.error(msg)
raise errors.IncompatibleHardwareMethodError(msg) raise errors.IncompatibleHardwareMethodError(msg)
@ -869,12 +869,12 @@ class GenericHardwareManager(HardwareManager):
if 'enabled' in security_lines: if 'enabled' in security_lines:
raise errors.BlockDeviceEraseError( raise errors.BlockDeviceEraseError(
('Block device {0} already has a security password set' ('Block device {} already has a security password set'
).format(block_device.name)) ).format(block_device.name))
if 'not frozen' not in security_lines: if 'not frozen' not in security_lines:
raise errors.BlockDeviceEraseError( raise errors.BlockDeviceEraseError(
('Block device {0} is frozen and cannot be erased' ('Block device {} is frozen and cannot be erased'
).format(block_device.name)) ).format(block_device.name))
try: try:
@ -905,7 +905,7 @@ class GenericHardwareManager(HardwareManager):
security_lines = self._get_ata_security_lines(block_device) security_lines = self._get_ata_security_lines(block_device)
if 'not enabled' not in security_lines: if 'not enabled' not in security_lines:
raise errors.BlockDeviceEraseError( raise errors.BlockDeviceEraseError(
('An unknown error occurred erasing block device {0}' ('An unknown error occurred erasing block device {}'
).format(block_device.name)) ).format(block_device.name))
return True return True
@ -982,7 +982,7 @@ def _get_managers():
for extension in extensions: for extension in extensions:
if extension.obj.evaluate_hardware_support() > 0: if extension.obj.evaluate_hardware_support() > 0:
preferred_managers.append(extension.obj) preferred_managers.append(extension.obj)
LOG.info('Hardware manager found: {0}'.format( LOG.info('Hardware manager found: {}'.format(
extension.entry_point_target)) extension.entry_point_target))
if not preferred_managers: if not preferred_managers:
@ -1019,7 +1019,7 @@ def dispatch_to_all_managers(method, *args, **kwargs):
try: try:
response = getattr(manager, method)(*args, **kwargs) response = getattr(manager, method)(*args, **kwargs)
except errors.IncompatibleHardwareMethodError: except errors.IncompatibleHardwareMethodError:
LOG.debug('HardwareManager {0} does not support {1}' LOG.debug('HardwareManager {} does not support {}'
.format(manager, method)) .format(manager, method))
continue continue
except Exception as e: except Exception as e:
@ -1029,7 +1029,7 @@ def dispatch_to_all_managers(method, *args, **kwargs):
raise raise
responses[manager.__class__.__name__] = response responses[manager.__class__.__name__] = response
else: else:
LOG.debug('HardwareManager {0} does not have method {1}' LOG.debug('HardwareManager {} does not have method {}'
.format(manager, method)) .format(manager, method))
if responses == {}: if responses == {}:
@ -1061,7 +1061,7 @@ def dispatch_to_managers(method, *args, **kwargs):
try: try:
return getattr(manager, method)(*args, **kwargs) return getattr(manager, method)(*args, **kwargs)
except(errors.IncompatibleHardwareMethodError): except(errors.IncompatibleHardwareMethodError):
LOG.debug('HardwareManager {0} does not support {1}' LOG.debug('HardwareManager {} does not support {}'
.format(manager, method)) .format(manager, method))
except Exception as e: except Exception as e:
LOG.exception('Unexpected error dispatching %(method)s to ' LOG.exception('Unexpected error dispatching %(method)s to '
@ -1069,7 +1069,7 @@ def dispatch_to_managers(method, *args, **kwargs):
{'method': method, 'manager': manager, 'e': e}) {'method': method, 'manager': manager, 'e': e})
raise raise
else: else:
LOG.debug('HardwareManager {0} does not have method {1}' LOG.debug('HardwareManager {} does not have method {}'
.format(manager, method)) .format(manager, method))
raise errors.HardwareManagerMethodNotFound(method) raise errors.HardwareManagerMethodNotFound(method)

View File

@ -93,7 +93,7 @@ class APIClient(object):
data = json.loads(response.content) data = json.loads(response.content)
raise errors.HeartbeatConflictError(data.get('faultstring')) raise errors.HeartbeatConflictError(data.get('faultstring'))
elif response.status_code != requests.codes.ACCEPTED: elif response.status_code != requests.codes.ACCEPTED:
msg = 'Invalid status code: {0}'.format(response.status_code) msg = 'Invalid status code: {}'.format(response.status_code)
raise errors.HeartbeatError(msg) raise errors.HeartbeatError(msg)
def lookup_node(self, hardware_info, timeout, starting_interval, def lookup_node(self, hardware_info, timeout, starting_interval,
@ -190,5 +190,5 @@ class APIClient(object):
raise loopingcall.LoopingCallDone(retvalue=content) raise loopingcall.LoopingCallDone(retvalue=content)
def _get_agent_url(self, advertise_address): def _get_agent_url(self, advertise_address):
return 'http://{0}:{1}'.format(advertise_address[0], return 'http://{}:{}'.format(advertise_address[0],
advertise_address[1]) advertise_address[1])

View File

@ -470,8 +470,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.agent_extension.cached_image_id) self.agent_extension.cached_image_id)
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('cache_image: image ({0}) cached to device ' cmd_result = ('cache_image: image ({}) cached to device '
'{1} ').format(image_info['id'], 'manager') '{} ').format(image_info['id'], 'manager')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@mock.patch('ironic_python_agent.hardware.dispatch_to_managers', @mock.patch('ironic_python_agent.hardware.dispatch_to_managers',
@ -495,9 +495,9 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.agent_extension.cached_image_id) self.agent_extension.cached_image_id)
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('cache_image: image ({0}) cached to device {1} ' cmd_result = ('cache_image: image ({}) cached to device {} '
'root_uuid={2}').format(image_info['id'], 'manager', 'root_uuid={}').format(image_info['id'], 'manager',
'root_uuid') 'root_uuid')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@mock.patch('ironic_python_agent.hardware.dispatch_to_managers', @mock.patch('ironic_python_agent.hardware.dispatch_to_managers',
@ -524,8 +524,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.agent_extension.cached_image_id) self.agent_extension.cached_image_id)
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('cache_image: image ({0}) cached to device ' cmd_result = ('cache_image: image ({}) cached to device '
'{1} ').format(image_info['id'], 'manager') '{} ').format(image_info['id'], 'manager')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@mock.patch('ironic_python_agent.hardware.dispatch_to_managers', @mock.patch('ironic_python_agent.hardware.dispatch_to_managers',
@ -550,8 +550,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.agent_extension.cached_image_id) self.agent_extension.cached_image_id)
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('cache_image: image ({0}) already present on device ' cmd_result = ('cache_image: image ({}) already present on device '
'{1} ').format(image_info['id'], 'manager') '{} ').format(image_info['id'], 'manager')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@mock.patch(('ironic_python_agent.extensions.standby.' @mock.patch(('ironic_python_agent.extensions.standby.'
@ -592,8 +592,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('prepare_image: image ({0}) written to device ' cmd_result = ('prepare_image: image ({}) written to device '
'{1} ').format(image_info['id'], 'manager') '{} ').format(image_info['id'], 'manager')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
download_mock.reset_mock() download_mock.reset_mock()
@ -613,8 +613,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('prepare_image: image ({0}) written to device ' cmd_result = ('prepare_image: image ({}) written to device '
'{1} ').format(image_info['id'], 'manager') '{} ').format(image_info['id'], 'manager')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@mock.patch(('ironic_python_agent.extensions.standby.' @mock.patch(('ironic_python_agent.extensions.standby.'
@ -654,8 +654,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('prepare_image: image ({0}) written to device {1} ' cmd_result = ('prepare_image: image ({}) written to device {} '
'root_uuid={2}').format( 'root_uuid={}').format(
image_info['id'], 'manager', 'root_uuid') image_info['id'], 'manager', 'root_uuid')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@ -675,8 +675,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('prepare_image: image ({0}) written to device {1} ' cmd_result = ('prepare_image: image ({}) written to device {} '
'root_uuid={2}').format( 'root_uuid={}').format(
image_info['id'], 'manager', 'root_uuid') image_info['id'], 'manager', 'root_uuid')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@ -713,8 +713,8 @@ class TestStandbyExtension(test_base.BaseTestCase):
self.assertEqual(0, configdrive_copy_mock.call_count) self.assertEqual(0, configdrive_copy_mock.call_count)
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertIn('result', async_result.command_result) self.assertIn('result', async_result.command_result)
cmd_result = ('prepare_image: image ({0}) written to device ' cmd_result = ('prepare_image: image ({}) written to device '
'{1} ').format(image_info['id'], 'manager') '{} ').format(image_info['id'], 'manager')
self.assertEqual(cmd_result, async_result.command_result['result']) self.assertEqual(cmd_result, async_result.command_result['result'])
@mock.patch(('ironic_python_agent.extensions.standby.' @mock.patch(('ironic_python_agent.extensions.standby.'
@ -882,7 +882,7 @@ class TestStandbyExtension(test_base.BaseTestCase):
def test__message_format_whole_disk(self): def test__message_format_whole_disk(self):
image_info = _build_fake_image_info() image_info = _build_fake_image_info()
msg = 'image ({0}) already present on device {1}' msg = 'image ({}) already present on device {}'
device = '/dev/fake' device = '/dev/fake'
partition_uuids = {} partition_uuids = {}
result_msg = standby._message_format(msg, image_info, result_msg = standby._message_format(msg, image_info,
@ -893,7 +893,7 @@ class TestStandbyExtension(test_base.BaseTestCase):
def test__message_format_partition_bios(self): def test__message_format_partition_bios(self):
image_info = _build_fake_partition_image_info() image_info = _build_fake_partition_image_info()
msg = ('image ({0}) already present on device {1} ') msg = ('image ({}) already present on device {} ')
device = '/dev/fake' device = '/dev/fake'
partition_uuids = {'root uuid': 'root_uuid', partition_uuids = {'root uuid': 'root_uuid',
'efi system partition uuid': None} 'efi system partition uuid': None}
@ -907,7 +907,7 @@ class TestStandbyExtension(test_base.BaseTestCase):
image_info = _build_fake_partition_image_info() image_info = _build_fake_partition_image_info()
image_info['deploy_boot_mode'] = 'uefi' image_info['deploy_boot_mode'] = 'uefi'
image_info['boot_option'] = 'netboot' image_info['boot_option'] = 'netboot'
msg = ('image ({0}) already present on device {1} ') msg = ('image ({}) already present on device {} ')
device = '/dev/fake' device = '/dev/fake'
partition_uuids = {'root uuid': 'root_uuid', partition_uuids = {'root uuid': 'root_uuid',
'efi system partition uuid': None} 'efi system partition uuid': None}
@ -921,7 +921,7 @@ class TestStandbyExtension(test_base.BaseTestCase):
image_info = _build_fake_partition_image_info() image_info = _build_fake_partition_image_info()
image_info['deploy_boot_mode'] = 'uefi' image_info['deploy_boot_mode'] = 'uefi'
image_info['boot_option'] = 'local' image_info['boot_option'] = 'local'
msg = ('image ({0}) already present on device {1} ') msg = ('image ({}) already present on device {} ')
device = '/dev/fake' device = '/dev/fake'
partition_uuids = {'root uuid': 'root_uuid', partition_uuids = {'root uuid': 'root_uuid',
'efi system partition uuid': 'efi_id'} 'efi system partition uuid': 'efi_id'}