mirror of
https://github.com/containers/podman-compose.git
synced 2025-01-24 14:58:50 +01:00
WIP #23: use cmd_quote
This commit is contained in:
parent
2f4da3fddb
commit
e21932e1de
@ -16,6 +16,11 @@ import time
|
|||||||
import re
|
import re
|
||||||
import hashlib
|
import hashlib
|
||||||
|
|
||||||
|
try:
|
||||||
|
from shlex import quote as cmd_quote
|
||||||
|
except ImportError:
|
||||||
|
from pipes import quote as cmd_quote
|
||||||
|
|
||||||
# import fnmatch
|
# import fnmatch
|
||||||
# fnmatch.fnmatchcase(env, "*_HOST")
|
# fnmatch.fnmatchcase(env, "*_HOST")
|
||||||
|
|
||||||
@ -406,6 +411,7 @@ def down(project_name, dirname, pods, containers, dry_run, podman_path):
|
|||||||
run_podman(dry_run, podman_path, ["pod", "rm", pod["name"]], sleep=0)
|
run_podman(dry_run, podman_path, ["pod", "rm", pod["name"]], sleep=0)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def container_to_args(cnt, dirname, podman_path, shared_vols):
|
def container_to_args(cnt, dirname, podman_path, shared_vols):
|
||||||
pod = cnt.get('pod') or ''
|
pod = cnt.get('pod') or ''
|
||||||
args = [
|
args = [
|
||||||
@ -475,29 +481,37 @@ def container_to_args(cnt, dirname, podman_path, shared_vols):
|
|||||||
else:
|
else:
|
||||||
args.extend(['--entrypoint', json.dumps(entrypoint)])
|
args.extend(['--entrypoint', json.dumps(entrypoint)])
|
||||||
|
|
||||||
healthcheck = cnt.get('healthcheck')
|
# WIP: healthchecks are still work in progress
|
||||||
if healthcheck is not None:
|
healthcheck = cnt.get('healthcheck', None) or {}
|
||||||
if is_dict(healthcheck):
|
if not is_dict(healthcheck):
|
||||||
if 'test' in healthcheck:
|
raise ValueError("'healthcheck' must be an key-value mapping")
|
||||||
command = healthcheck['test']
|
healthcheck_test = healthcheck.get('test')
|
||||||
# test must be either a string or a list. If it’s a list,
|
if healthcheck_test:
|
||||||
# the first item must be either NONE, CMD or CMD-SHELL.
|
|
||||||
# If it’s a string, it’s equivalent to specifying CMD-SHELL
|
# If it’s a string, it’s equivalent to specifying CMD-SHELL
|
||||||
# followed by that string.
|
if is_str(healthcheck_test):
|
||||||
if is_str(command):
|
|
||||||
if re.search(r'\s', command):
|
|
||||||
# podman does not add shell to handle command with whitespace
|
# podman does not add shell to handle command with whitespace
|
||||||
args.extend(['--healthcheck-command', '"/bin/bash -c \'{}\'"'.format(command)])
|
args.extend(['--healthcheck-command', '/bin/sh -c {}'.format(cmd_quote(healthcheck_test))])
|
||||||
|
elif is_list(healthcheck_test):
|
||||||
|
# If it’s a list, first item is either NONE, CMD or CMD-SHELL.
|
||||||
|
healthcheck_type = healthcheck_test.pop(0)
|
||||||
|
if healthcheck_type == 'NONE':
|
||||||
|
args.append("--no-healthcheck")
|
||||||
|
elif healthcheck_type == 'CMD':
|
||||||
|
args.extend(['--healthcheck-command', '/bin/sh -c {}'.format(
|
||||||
|
"' '".join([cmd_quote(i) for i in healthcheck_test])
|
||||||
|
)])
|
||||||
|
elif healthcheck_type == 'CMD-SHELL':
|
||||||
|
if len(healthcheck_test)!=1:
|
||||||
|
raise ValueError("'CMD_SHELL' takes a single string after it")
|
||||||
|
args.extend(['--healthcheck-command', '/bin/sh -c {}'.format(cmd_quote(healthcheck_test[0])]))
|
||||||
else:
|
else:
|
||||||
args.extend(['--healthcheck-command', command])
|
raise ValueError(
|
||||||
elif command[0] == 'NONE':
|
"unknown healthcheck test type [{}],\
|
||||||
args.extend(['--healthcheck-command', 'none'])
|
expecting NONE, CMD or CMD-SHELL."
|
||||||
elif command[0] == 'CMD-SHELL':
|
.format(healthcheck_type)
|
||||||
# podman does not add shell to handle command with whitespace
|
)
|
||||||
args.extend(['--healthcheck-command', '"/bin/bash -c \'{}\'"'.format(command[1])])
|
|
||||||
else:
|
else:
|
||||||
# podman splits string on white space
|
raise ValueError("'healthcheck.test' either a string or a list")
|
||||||
args.extend(['--healthcheck-command', '"{}"'.format(' '.join(command[1:]))])
|
|
||||||
|
|
||||||
# interval, timeout and start_period are specified as durations.
|
# interval, timeout and start_period are specified as durations.
|
||||||
if 'interval' in healthcheck:
|
if 'interval' in healthcheck:
|
||||||
@ -510,8 +524,6 @@ def container_to_args(cnt, dirname, podman_path, shared_vols):
|
|||||||
# convert other parameters to string
|
# convert other parameters to string
|
||||||
if 'retries' in healthcheck:
|
if 'retries' in healthcheck:
|
||||||
args.extend(['--healthcheck-retries', '{}'.format(healthcheck['retries'])])
|
args.extend(['--healthcheck-retries', '{}'.format(healthcheck['retries'])])
|
||||||
else:
|
|
||||||
raise ValueError("'healthcheck' must be an associative array")
|
|
||||||
|
|
||||||
args.append(cnt.get('image')) # command, ..etc.
|
args.append(cnt.get('image')) # command, ..etc.
|
||||||
command = cnt.get('command')
|
command = cnt.get('command')
|
||||||
|
Loading…
Reference in New Issue
Block a user