Shorten too long lines

Signed-off-by: Povilas Kanapickas <povilas@radix.lt>
This commit is contained in:
Povilas Kanapickas 2024-03-08 23:46:24 +02:00
parent 91052cb2d9
commit 4e43606df3
5 changed files with 37 additions and 24 deletions

View File

@ -125,7 +125,8 @@ def str_to_seconds(txt):
mins = int(mins) if mins else 0 mins = int(mins) if mins else 0
sec = float(sec) if sec else 0 sec = float(sec) if sec else 0
# "podman stop" takes only int # "podman stop" takes only int
# Error: invalid argument "3.0" for "-t, --time" flag: strconv.ParseUint: parsing "3.0": invalid syntax # Error: invalid argument "3.0" for "-t, --time" flag: strconv.ParseUint: parsing "3.0":
# invalid syntax
return int(mins * 60.0 + sec) return int(mins * 60.0 + sec)
@ -388,7 +389,8 @@ async def assert_volume(compose, mount_dict):
is_ext = vol.get("external", None) is_ext = vol.get("external", None)
log(f"podman volume inspect {vol_name} || podman volume create {vol_name}") log(f"podman volume inspect {vol_name} || podman volume create {vol_name}")
# TODO: might move to using "volume list" # TODO: might move to using "volume list"
# podman volume list --format '{{.Name}}\t{{.MountPoint}}' -f 'label=io.podman.compose.project=HERE' # podman volume list --format '{{.Name}}\t{{.MountPoint}}' \
# -f 'label=io.podman.compose.project=HERE'
try: try:
_ = (await compose.podman.output([], "volume", ["inspect", vol_name])).decode("utf-8") _ = (await compose.podman.output([], "volume", ["inspect", vol_name])).decode("utf-8")
except subprocess.CalledProcessError as e: except subprocess.CalledProcessError as e:
@ -583,7 +585,10 @@ def get_secret_args(compose, cnt, secret):
# having a custom name for the external secret # having a custom name for the external secret
# has the same problem as well # has the same problem as well
ext_name = declared_secret.get("name", None) ext_name = declared_secret.get("name", None)
err_str = 'ERROR: Custom name/target reference "{}" for mounted external secret "{}" is not supported' err_str = (
'ERROR: Custom name/target reference "{}" '
'for mounted external secret "{}" is not supported'
)
if ext_name and ext_name != secret_name: if ext_name and ext_name != secret_name:
raise ValueError(err_str.format(secret_name, ext_name)) raise ValueError(err_str.format(secret_name, ext_name))
if target and target != secret_name: if target and target != secret_name:
@ -1527,7 +1532,8 @@ class PodmanCompose:
files = args.file files = args.file
if not files: if not files:
log( log(
"no compose.yaml, docker-compose.yml or container-compose.yml file found, pass files with -f" "no compose.yaml, docker-compose.yml or container-compose.yml file found, "
"pass files with -f"
) )
sys.exit(-1) sys.exit(-1)
ex = map(os.path.exists, files) ex = map(os.path.exists, files)
@ -1617,7 +1623,8 @@ class PodmanCompose:
if not project_name: if not project_name:
project_name = compose.get("name", None) project_name = compose.get("name", None)
if project_name is None: if project_name is None:
# More strict then actually needed for simplicity: podman requires [a-zA-Z0-9][a-zA-Z0-9_.-]* # More strict then actually needed for simplicity:
# podman requires [a-zA-Z0-9][a-zA-Z0-9_.-]*
project_name = ( project_name = (
self.environ.get("COMPOSE_PROJECT_NAME", None) or dir_basename.lower() self.environ.get("COMPOSE_PROJECT_NAME", None) or dir_basename.lower()
) )
@ -1740,11 +1747,11 @@ class PodmanCompose:
def _resolve_profiles(self, defined_services, requested_profiles=None): def _resolve_profiles(self, defined_services, requested_profiles=None):
""" """
Returns a service dictionary (key = service name, value = service config) compatible with the requested_profiles Returns a service dictionary (key = service name, value = service config) compatible with
list. the requested_profiles list.
The returned service dictionary contains all services which do not include/reference a profile in addition to The returned service dictionary contains all services which do not include/reference a
services that match the requested_profiles. profile in addition to services that match the requested_profiles.
:param defined_services: The service dictionary :param defined_services: The service dictionary
:param requested_profiles: The profiles requested using the --profile arg. :param requested_profiles: The profiles requested using the --profile arg.
@ -2255,8 +2262,9 @@ async def compose_up(compose: PodmanCompose, args):
done, tasks = await asyncio.wait(tasks, return_when=asyncio.FIRST_COMPLETED) done, tasks = await asyncio.wait(tasks, return_when=asyncio.FIRST_COMPLETED)
if args.abort_on_container_exit: if args.abort_on_container_exit:
if not exiting: if not exiting:
# If 2 containers exit at the exact same time, the cancellation of the other ones cause the status # If 2 containers exit at the exact same time, the cancellation of the other ones
# to overwrite. Sleeping for 1 seems to fix this and make it match docker-compose # cause the status to overwrite. Sleeping for 1 seems to fix this and make it match
# docker-compose
await asyncio.sleep(1) await asyncio.sleep(1)
[_.cancel() for _ in tasks if not _.cancelling() and not _.cancelled()] [_.cancel() for _ in tasks if not _.cancelling() and not _.cancelled()]
t: Task t: Task
@ -2726,7 +2734,8 @@ def compose_up_parse(parser):
parser.add_argument( parser.add_argument(
"--no-recreate", "--no-recreate",
action="store_true", action="store_true",
help="If containers already exist, don't recreate them. Incompatible with --force-recreate and -V.", help="If containers already exist, don't recreate them. Incompatible with --force-recreate "
"and -V.",
) )
parser.add_argument( parser.add_argument(
"--no-build", "--no-build",
@ -2751,8 +2760,8 @@ def compose_up_parse(parser):
"--timeout", "--timeout",
type=int, type=int,
default=None, default=None,
help="Use this timeout in seconds for container shutdown when attached or when containers are already running. \ help="Use this timeout in seconds for container shutdown when attached or when containers "
(default: 10)", "are already running. (default: 10)",
) )
parser.add_argument( parser.add_argument(
"-V", "-V",
@ -2769,14 +2778,16 @@ def compose_up_parse(parser):
"--scale", "--scale",
metavar="SERVICE=NUM", metavar="SERVICE=NUM",
action="append", action="append",
help="Scale SERVICE to NUM instances. Overrides the `scale` setting in the Compose file if present.", help="Scale SERVICE to NUM instances. Overrides the `scale` setting in the Compose file if "
"present.",
) )
parser.add_argument( parser.add_argument(
"--exit-code-from", "--exit-code-from",
metavar="SERVICE", metavar="SERVICE",
type=str, type=str,
default=None, default=None,
help="Return the exit code of the selected service container. Implies --abort-on-container-exit.", help="Return the exit code of the selected service container. "
"Implies --abort-on-container-exit.",
) )
@ -3018,7 +3029,8 @@ def compose_build_up_parse(parser):
) )
parser.add_argument( parser.add_argument(
"--pull-always", "--pull-always",
help="attempt to pull a newer version of the image, Raise an error even if the image is present locally.", help="attempt to pull a newer version of the image, Raise an error even if the image is "
"present locally.",
action="store_true", action="store_true",
) )
parser.add_argument( parser.add_argument(

View File

@ -78,8 +78,8 @@ class TestPodmanCompose(unittest.TestCase, RunSubprocessMixin):
def test_extends_w_empty_service(self): def test_extends_w_empty_service(self):
""" """
Test that podman-compose can execute podman-compose -f <file> up with extended File which Test that podman-compose can execute podman-compose -f <file> up with extended File which
includes an empty service. (e.g. if the file is used as placeholder for more complex configurations.) includes an empty service. (e.g. if the file is used as placeholder for more complex
:return: configurations.)
""" """
main_path = Path(__file__).parent.parent main_path = Path(__file__).parent.parent

View File

@ -63,8 +63,8 @@ class TestComposeConfig(unittest.TestCase, RunSubprocessMixin):
""" """
Tests podman-compose Tests podman-compose
:param profiles: The enabled profiles for the parameterized test. :param profiles: The enabled profiles for the parameterized test.
:param expected_services: Dictionary used to model the expected "enabled" services in the profile. :param expected_services: Dictionary used to model the expected "enabled" services in the
Key = service name, Value = True if the service is enabled, otherwise False. profile. Key = service name, Value = True if the service is enabled, otherwise False.
""" """
config_cmd = ["coverage", "run", podman_compose_path(), "-f", profile_compose_file()] config_cmd = ["coverage", "run", podman_compose_path(), "-f", profile_compose_file()]
config_cmd.extend(profiles) config_cmd.extend(profiles)

View File

@ -50,8 +50,8 @@ class TestPodmanCompose(unittest.TestCase, RunSubprocessMixin):
out, _ = self.run_subprocess_assert_returncode(run_cmd) out, _ = self.run_subprocess_assert_returncode(run_cmd)
self.assertIn(b'127.0.0.1\tlocalhost', out) self.assertIn(b'127.0.0.1\tlocalhost', out)
# Run it again to make sure we can run it twice. I saw an issue where a second run, with the container left up, # Run it again to make sure we can run it twice. I saw an issue where a second run, with
# would fail # the container left up, would fail
run_cmd = [ run_cmd = [
"coverage", "coverage",
"run", "run",

View File

@ -25,7 +25,8 @@ def profile_compose_file():
class TestUpDown(unittest.TestCase, RunSubprocessMixin): class TestUpDown(unittest.TestCase, RunSubprocessMixin):
def tearDown(self): def tearDown(self):
""" """
Ensures that the services within the "profile compose file" are removed between each test case. Ensures that the services within the "profile compose file" are removed between each test
case.
""" """
# run the test case # run the test case