Run pyupgrade to clean up Python 2 syntaxes

Update all .py source files by
 $ pyupgrade --py3-only $(git ls-files | grep ".py$")
to modernize the code according to Python 3 syntaxes.

Also add the pyupgrade hook to pre-commit to avoid merging additional
Python 2 syntaxes.

Change-Id: I9d54c11642acb341cc5db1267f5a91d4740f932c
This commit is contained in:
Takashi Kajinami 2024-10-19 23:08:04 +09:00
parent ca6388b5a2
commit 1f5ba0ca87
9 changed files with 43 additions and 39 deletions

View File

@ -1,6 +1,6 @@
repos: repos:
- repo: https://github.com/pre-commit/pre-commit-hooks - repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.5.0 rev: v5.0.0
hooks: hooks:
- id: trailing-whitespace - id: trailing-whitespace
# Replaces or checks mixed line ending # Replaces or checks mixed line ending
@ -19,12 +19,17 @@ repos:
- id: check-yaml - id: check-yaml
files: .*\.(yaml|yml)$ files: .*\.(yaml|yml)$
- repo: https://opendev.org/openstack/hacking - repo: https://opendev.org/openstack/hacking
rev: 6.1.0 rev: 7.0.0
hooks: hooks:
- id: hacking - id: hacking
additional_dependencies: [] additional_dependencies: []
- repo: https://github.com/PyCQA/bandit - repo: https://github.com/PyCQA/bandit
rev: 1.7.6 rev: 1.7.10
hooks: hooks:
- id: bandit - id: bandit
args: ['-x', 'tests', '-s', 'B311,B404,B603,B606'] args: ['-x', 'tests', '-s', 'B311,B404,B603,B606']
- repo: https://github.com/asottile/pyupgrade
rev: v3.18.0
hooks:
- id: pyupgrade
args: [--py3-only]

View File

@ -1,4 +1,3 @@
# -*- coding: utf-8 -*-
# Copyright (C) 2020 Red Hat, Inc. # Copyright (C) 2020 Red Hat, Inc.
# #
# Licensed under the Apache License, Version 2.0 (the "License"); # Licensed under the Apache License, Version 2.0 (the "License");

View File

@ -47,7 +47,7 @@ class LockFixture(fixtures.Fixture):
self.mgr = lockutils.lock(name, lock_file_prefix, True) self.mgr = lockutils.lock(name, lock_file_prefix, True)
def setUp(self): def setUp(self):
super(LockFixture, self).setUp() super().setUp()
self.addCleanup(self.mgr.__exit__, None, None, None) self.addCleanup(self.mgr.__exit__, None, None, None)
self.lock = self.mgr.__enter__() self.lock = self.mgr.__enter__()
@ -72,7 +72,7 @@ class ExternalLockFixture(fixtures.Fixture):
.. versionadded:: 0.3 .. versionadded:: 0.3
""" """
def setUp(self): def setUp(self):
super(ExternalLockFixture, self).setUp() super().setUp()
temp_dir = self.useFixture(fixtures.TempDir()) temp_dir = self.useFixture(fixtures.TempDir())
conf = self.useFixture(config.Config(lockutils.CONF)).config conf = self.useFixture(config.Config(lockutils.CONF)).config
conf(lock_path=temp_dir.path, group='oslo_concurrency') conf(lock_path=temp_dir.path, group='oslo_concurrency')

View File

@ -104,7 +104,7 @@ class ReaderWriterLock(fasteners.ReaderWriterLock):
InterProcessLock = fasteners.InterProcessLock InterProcessLock = fasteners.InterProcessLock
class FairLocks(object): class FairLocks:
"""A garbage collected container of fair locks. """A garbage collected container of fair locks.
With a fair lock, contending lockers will get the lock in the order in With a fair lock, contending lockers will get the lock in the order in
@ -147,7 +147,7 @@ def internal_fair_lock(name):
return _fair_locks.get(name) return _fair_locks.get(name)
class Semaphores(object): class Semaphores:
"""A garbage collected container of semaphores. """A garbage collected container of semaphores.
This collection internally uses a weak value dictionary so that when a This collection internally uses a weak value dictionary so that when a
@ -192,7 +192,7 @@ def _get_lock_path(name, lock_file_prefix, lock_path=None):
name = name.replace(os.sep, '_') name = name.replace(os.sep, '_')
if lock_file_prefix: if lock_file_prefix:
sep = '' if lock_file_prefix.endswith('-') else '-' sep = '' if lock_file_prefix.endswith('-') else '-'
name = '%s%s%s' % (lock_file_prefix, sep, name) name = '{}{}{}'.format(lock_file_prefix, sep, name)
local_lock_path = lock_path or CONF.oslo_concurrency.lock_path local_lock_path = lock_path or CONF.oslo_concurrency.lock_path

View File

@ -70,18 +70,18 @@ LOG = logging.getLogger(__name__)
class InvalidArgumentError(Exception): class InvalidArgumentError(Exception):
def __init__(self, message=None): def __init__(self, message=None):
super(InvalidArgumentError, self).__init__(message) super().__init__(message)
class UnknownArgumentError(Exception): class UnknownArgumentError(Exception):
def __init__(self, message=None): def __init__(self, message=None):
super(UnknownArgumentError, self).__init__(message) super().__init__(message)
class ProcessExecutionError(Exception): class ProcessExecutionError(Exception):
def __init__(self, stdout=None, stderr=None, exit_code=None, cmd=None, def __init__(self, stdout=None, stderr=None, exit_code=None, cmd=None,
description=None): description=None):
super(ProcessExecutionError, self).__init__( super().__init__(
stdout, stderr, exit_code, cmd, description) stdout, stderr, exit_code, cmd, description)
self.exit_code = exit_code self.exit_code = exit_code
self.stderr = stderr self.stderr = stderr
@ -112,7 +112,7 @@ class ProcessExecutionError(Exception):
class NoRootWrapSpecified(Exception): class NoRootWrapSpecified(Exception):
def __init__(self, message=None): def __init__(self, message=None):
super(NoRootWrapSpecified, self).__init__(message) super().__init__(message)
def _subprocess_setup(on_preexec_fn): def _subprocess_setup(on_preexec_fn):
@ -146,7 +146,7 @@ LOG_FINAL_ERROR = LogErrors.FINAL
LOG_DEFAULT_ERROR = LogErrors.DEFAULT LOG_DEFAULT_ERROR = LogErrors.DEFAULT
class ProcessLimits(object): class ProcessLimits:
"""Resource limits on a process. """Resource limits on a process.
Attributes: Attributes:
@ -192,7 +192,7 @@ class ProcessLimits(object):
for limit in self._LIMITS: for limit in self._LIMITS:
val = getattr(self, limit) val = getattr(self, limit)
if val is not None: if val is not None:
args.append("%s=%s" % (self._LIMITS[limit], val)) args.append("{}={}".format(self._LIMITS[limit], val))
return args return args

View File

@ -68,7 +68,7 @@ def lock_files(handles_dir, out_queue):
lock_file(handle) lock_file(handle)
count += 1 count += 1
unlock_file(handle) unlock_file(handle)
except IOError: except OSError:
os._exit(2) os._exit(2)
finally: finally:
handle.close() handle.close()
@ -78,7 +78,7 @@ def lock_files(handles_dir, out_queue):
class LockTestCase(test_base.BaseTestCase): class LockTestCase(test_base.BaseTestCase):
def setUp(self): def setUp(self):
super(LockTestCase, self).setUp() super().setUp()
self.config = self.useFixture(config.Config(lockutils.CONF)).config self.config = self.useFixture(config.Config(lockutils.CONF)).config
def test_synchronized_wrapped_function_metadata(self): def test_synchronized_wrapped_function_metadata(self):
@ -363,7 +363,7 @@ class LockTestCase(test_base.BaseTestCase):
class FileBasedLockingTestCase(test_base.BaseTestCase): class FileBasedLockingTestCase(test_base.BaseTestCase):
def setUp(self): def setUp(self):
super(FileBasedLockingTestCase, self).setUp() super().setUp()
self.lock_dir = tempfile.mkdtemp() self.lock_dir = tempfile.mkdtemp()
def test_lock_file_exists(self): def test_lock_file_exists(self):
@ -399,7 +399,7 @@ class FileBasedLockingTestCase(test_base.BaseTestCase):
lock1.trylock() lock1.trylock()
lock1.unlock() lock1.unlock()
time.sleep(0) time.sleep(0)
except IOError: except OSError:
# This is what we expect to happen # This is what we expect to happen
break break
else: else:
@ -415,7 +415,7 @@ class FileBasedLockingTestCase(test_base.BaseTestCase):
try: try:
lock2.trylock() lock2.trylock()
have_lock = True have_lock = True
except IOError: except OSError:
pass pass
finally: finally:
# NOTE(bnemec): This is racy, but I don't want to add any # NOTE(bnemec): This is racy, but I don't want to add any
@ -557,7 +557,7 @@ class FileBasedLockingTestCase(test_base.BaseTestCase):
class LockutilsModuleTestCase(test_base.BaseTestCase): class LockutilsModuleTestCase(test_base.BaseTestCase):
def setUp(self): def setUp(self):
super(LockutilsModuleTestCase, self).setUp() super().setUp()
self.old_env = os.environ.get('OSLO_LOCK_PATH') self.old_env = os.environ.get('OSLO_LOCK_PATH')
if self.old_env is not None: if self.old_env is not None:
del os.environ['OSLO_LOCK_PATH'] del os.environ['OSLO_LOCK_PATH']
@ -565,7 +565,7 @@ class LockutilsModuleTestCase(test_base.BaseTestCase):
def tearDown(self): def tearDown(self):
if self.old_env is not None: if self.old_env is not None:
os.environ['OSLO_LOCK_PATH'] = self.old_env os.environ['OSLO_LOCK_PATH'] = self.old_env
super(LockutilsModuleTestCase, self).tearDown() super().tearDown()
def test_main(self): def test_main(self):
script = '\n'.join([ script = '\n'.join([
@ -597,7 +597,7 @@ class LockutilsModuleTestCase(test_base.BaseTestCase):
class TestLockFixture(test_base.BaseTestCase): class TestLockFixture(test_base.BaseTestCase):
def setUp(self): def setUp(self):
super(TestLockFixture, self).setUp() super().setUp()
self.config = self.useFixture(config.Config(lockutils.CONF)).config self.config = self.useFixture(config.Config(lockutils.CONF)).config
self.tempdir = tempfile.mkdtemp() self.tempdir = tempfile.mkdtemp()
@ -606,7 +606,7 @@ class TestLockFixture(test_base.BaseTestCase):
def tearDown(self): def tearDown(self):
self._check_in_lock() self._check_in_lock()
super(TestLockFixture, self).tearDown() super().tearDown()
def test_lock_fixture(self): def test_lock_fixture(self):
# Setup lock fixture to test that teardown is inside the lock # Setup lock fixture to test that teardown is inside the lock
@ -619,7 +619,7 @@ class TestLockFixture(test_base.BaseTestCase):
class TestGetLockPath(test_base.BaseTestCase): class TestGetLockPath(test_base.BaseTestCase):
def setUp(self): def setUp(self):
super(TestGetLockPath, self).setUp() super().setUp()
self.conf = self.useFixture(config.Config(lockutils.CONF)).conf self.conf = self.useFixture(config.Config(lockutils.CONF)).conf
def test_get_default(self): def test_get_default(self):

View File

@ -89,7 +89,7 @@ class UtilsTest(test_base.BaseTestCase):
on_completion_callback = mock.Mock() on_completion_callback = mock.Mock()
def fake_communicate(*args, timeout=None): def fake_communicate(*args, timeout=None):
raise IOError("Broken pipe") raise OSError("Broken pipe")
mock_comm.side_effect = fake_communicate mock_comm.side_effect = fake_communicate
@ -128,7 +128,7 @@ class UtilsTest(test_base.BaseTestCase):
mock_comm.return_value = None mock_comm.return_value = None
mock_tpool.execute.return_value = mock_comm.return_value mock_tpool.execute.return_value = mock_comm.return_value
fake_pinput = 'fake pinput'.encode('utf-8') fake_pinput = b'fake pinput'
with mock.patch.object(processutils, 'eventlet_patched', with mock.patch.object(processutils, 'eventlet_patched',
use_eventlet): use_eventlet):
@ -240,7 +240,7 @@ exit 1
tmpfilename, tmpfilename2, attempts=10, tmpfilename, tmpfilename2, attempts=10,
process_input=b'foo', process_input=b'foo',
delay_on_retry=False) delay_on_retry=False)
fp = open(tmpfilename2, 'r') fp = open(tmpfilename2)
runs = fp.read() runs = fp.read()
fp.close() fp.close()
self.assertNotEqual('failure', 'stdin did not ' self.assertNotEqual('failure', 'stdin did not '
@ -320,7 +320,7 @@ grep foo
# This test and the one below ensures that when communicate raises # This test and the one below ensures that when communicate raises
# an OSError, we do the right thing(s) # an OSError, we do the right thing(s)
def test_exception_on_communicate_error(self): def test_exception_on_communicate_error(self):
mock = self.useFixture(fixtures.MockPatch( mock_comm = self.useFixture(fixtures.MockPatch(
'subprocess.Popen.communicate', 'subprocess.Popen.communicate',
side_effect=OSError(errno.EAGAIN, 'fake-test'))) side_effect=OSError(errno.EAGAIN, 'fake-test')))
@ -330,10 +330,10 @@ grep foo
'false', 'false',
check_exit_code=False) check_exit_code=False)
self.assertEqual(1, mock.mock.call_count) self.assertEqual(1, mock_comm.mock.call_count)
def test_retry_on_communicate_error(self): def test_retry_on_communicate_error(self):
mock = self.useFixture(fixtures.MockPatch( mock_comm = self.useFixture(fixtures.MockPatch(
'subprocess.Popen.communicate', 'subprocess.Popen.communicate',
side_effect=OSError(errno.EAGAIN, 'fake-test'))) side_effect=OSError(errno.EAGAIN, 'fake-test')))
@ -344,11 +344,11 @@ grep foo
check_exit_code=False, check_exit_code=False,
attempts=5) attempts=5)
self.assertEqual(5, mock.mock.call_count) self.assertEqual(5, mock_comm.mock.call_count)
def _test_and_check_logging_communicate_errors(self, log_errors=None, def _test_and_check_logging_communicate_errors(self, log_errors=None,
attempts=None): attempts=None):
mock = self.useFixture(fixtures.MockPatch( mock_comm = self.useFixture(fixtures.MockPatch(
'subprocess.Popen.communicate', 'subprocess.Popen.communicate',
side_effect=OSError(errno.EAGAIN, 'fake-test'))) side_effect=OSError(errno.EAGAIN, 'fake-test')))
@ -367,7 +367,8 @@ grep foo
'false', 'false',
**kwargs) **kwargs)
self.assertEqual(attempts if attempts else 1, mock.mock.call_count) self.assertEqual(attempts if attempts else 1,
mock_comm.mock.call_count)
self.assertIn('Got an OSError', fixture.output) self.assertIn('Got an OSError', fixture.output)
self.assertIn('errno: %d' % errno.EAGAIN, fixture.output) self.assertIn('errno: %d' % errno.EAGAIN, fixture.output)
self.assertIn("'/usr/bin/env false'", fixture.output) self.assertIn("'/usr/bin/env false'", fixture.output)
@ -530,7 +531,7 @@ grep foo
class ProcessExecutionErrorLoggingTest(test_base.BaseTestCase): class ProcessExecutionErrorLoggingTest(test_base.BaseTestCase):
def setUp(self): def setUp(self):
super(ProcessExecutionErrorLoggingTest, self).setUp() super().setUp()
self.tmpfilename = self.create_tempfiles( self.tmpfilename = self.create_tempfiles(
[["process_execution_error_logging_test", [["process_execution_error_logging_test",
PROCESS_EXECUTION_ERROR_LOGGING_TEST]], PROCESS_EXECUTION_ERROR_LOGGING_TEST]],
@ -624,7 +625,7 @@ class TryCmdTestCase(test_base.BaseTestCase):
self.assertEqual('', e) self.assertEqual('', e)
class FakeSshChannel(object): class FakeSshChannel:
def __init__(self, rc): def __init__(self, rc):
self.rc = rc self.rc = rc
@ -637,7 +638,7 @@ class FakeSshStream(io.BytesIO):
self.channel = FakeSshChannel(rc) self.channel = FakeSshChannel(rc)
class FakeSshConnection(object): class FakeSshConnection:
def __init__(self, rc, out=b'stdout', err=b'stderr'): def __init__(self, rc, out=b'stdout', err=b'stderr'):
self.rc = rc self.rc = rc
self.out = out self.out = out

View File

@ -64,7 +64,7 @@ def watch(logger, action, level=logging.DEBUG, after=5.0):
watch.start() watch.start()
def log(): def log():
msg = "%s not completed after %0.3fs" % (action, watch.elapsed()) msg = "{} not completed after {:0.3f}s".format(action, watch.elapsed())
logger.log(level, msg) logger.log(level, msg)
timer = threading.Timer(after, log) timer = threading.Timer(after, log)

View File

@ -1,4 +1,3 @@
# -*- coding: utf-8 -*-
# Licensed under the Apache License, Version 2.0 (the "License"); # Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License. # you may not use this file except in compliance with the License.
# You may obtain a copy of the License at # You may obtain a copy of the License at