mirror of
https://github.com/containers/podman-compose.git
synced 2025-01-22 05:49:04 +01:00
commit
970e4ac4ab
@ -956,8 +956,18 @@ async def container_to_args(compose, cnt, detached=True):
|
|||||||
podman_args.append("-i")
|
podman_args.append("-i")
|
||||||
if cnt.get("stop_signal", None):
|
if cnt.get("stop_signal", None):
|
||||||
podman_args.extend(["--stop-signal", cnt["stop_signal"]])
|
podman_args.extend(["--stop-signal", cnt["stop_signal"]])
|
||||||
for i in cnt.get("sysctls", []):
|
|
||||||
|
sysctls = cnt.get("sysctls")
|
||||||
|
if sysctls is not None:
|
||||||
|
if isinstance(sysctls, dict):
|
||||||
|
for sysctl, value in sysctls.items():
|
||||||
|
podman_args.extend(["--sysctl", "{}={}".format(sysctl, value)])
|
||||||
|
elif isinstance(sysctls, list):
|
||||||
|
for i in sysctls:
|
||||||
podman_args.extend(["--sysctl", i])
|
podman_args.extend(["--sysctl", i])
|
||||||
|
else:
|
||||||
|
raise TypeError("sysctls should be either dict or list")
|
||||||
|
|
||||||
if cnt.get("tty", None):
|
if cnt.get("tty", None):
|
||||||
podman_args.append("--tty")
|
podman_args.append("--tty")
|
||||||
if cnt.get("privileged", None):
|
if cnt.get("privileged", None):
|
||||||
|
@ -25,7 +25,7 @@ def get_minimal_container():
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class TestContainerToArgs(unittest.TestCase):
|
class TestContainerToArgs(unittest.IsolatedAsyncioTestCase):
|
||||||
async def test_minimal(self):
|
async def test_minimal(self):
|
||||||
c = create_compose_mock()
|
c = create_compose_mock()
|
||||||
|
|
||||||
@ -66,3 +66,67 @@ class TestContainerToArgs(unittest.TestCase):
|
|||||||
"busybox",
|
"busybox",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
async def test_sysctl_list(self):
|
||||||
|
c = create_compose_mock()
|
||||||
|
|
||||||
|
cnt = get_minimal_container()
|
||||||
|
cnt["sysctls"] = [
|
||||||
|
"net.core.somaxconn=1024",
|
||||||
|
"net.ipv4.tcp_syncookies=0",
|
||||||
|
]
|
||||||
|
|
||||||
|
args = await container_to_args(c, cnt)
|
||||||
|
self.assertEqual(
|
||||||
|
args,
|
||||||
|
[
|
||||||
|
"--name=project_name_service_name1",
|
||||||
|
"-d",
|
||||||
|
"--net",
|
||||||
|
"",
|
||||||
|
"--network-alias",
|
||||||
|
"service_name",
|
||||||
|
"--sysctl",
|
||||||
|
"net.core.somaxconn=1024",
|
||||||
|
"--sysctl",
|
||||||
|
"net.ipv4.tcp_syncookies=0",
|
||||||
|
"busybox",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
async def test_sysctl_map(self):
|
||||||
|
c = create_compose_mock()
|
||||||
|
|
||||||
|
cnt = get_minimal_container()
|
||||||
|
cnt["sysctls"] = {
|
||||||
|
"net.core.somaxconn": 1024,
|
||||||
|
"net.ipv4.tcp_syncookies": 0,
|
||||||
|
}
|
||||||
|
|
||||||
|
args = await container_to_args(c, cnt)
|
||||||
|
self.assertEqual(
|
||||||
|
args,
|
||||||
|
[
|
||||||
|
"--name=project_name_service_name1",
|
||||||
|
"-d",
|
||||||
|
"--net",
|
||||||
|
"",
|
||||||
|
"--network-alias",
|
||||||
|
"service_name",
|
||||||
|
"--sysctl",
|
||||||
|
"net.core.somaxconn=1024",
|
||||||
|
"--sysctl",
|
||||||
|
"net.ipv4.tcp_syncookies=0",
|
||||||
|
"busybox",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
async def test_sysctl_wrong_type(self):
|
||||||
|
c = create_compose_mock()
|
||||||
|
cnt = get_minimal_container()
|
||||||
|
|
||||||
|
# check whether wrong types are correctly rejected
|
||||||
|
for wrong_type in [True, 0, 0.0, "wrong", ()]:
|
||||||
|
with self.assertRaises(TypeError):
|
||||||
|
cnt["sysctls"] = wrong_type
|
||||||
|
await container_to_args(c, cnt)
|
||||||
|
Loading…
Reference in New Issue
Block a user