2021-12-09 03:10:44 +01:00
|
|
|
import ../make-test-python.nix (
|
2020-04-20 13:35:36 +02:00
|
|
|
{ pkgs, lib, ... }: {
|
2020-04-20 10:37:53 +02:00
|
|
|
name = "podman";
|
2020-04-20 13:35:36 +02:00
|
|
|
meta = {
|
|
|
|
maintainers = lib.teams.podman.members;
|
2020-04-20 10:37:53 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
nodes = {
|
2022-11-06 01:28:37 +01:00
|
|
|
podman = { pkgs, ... }: {
|
|
|
|
virtualisation.podman.enable = true;
|
|
|
|
|
|
|
|
users.users.alice = {
|
|
|
|
isNormalUser = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
docker = { pkgs, ... }: {
|
|
|
|
virtualisation.podman.enable = true;
|
|
|
|
|
|
|
|
virtualisation.podman.dockerSocket.enable = true;
|
|
|
|
|
|
|
|
environment.systemPackages = [
|
|
|
|
pkgs.docker-client
|
|
|
|
];
|
2020-04-24 11:49:36 +02:00
|
|
|
|
2022-11-06 01:28:37 +01:00
|
|
|
users.users.alice = {
|
|
|
|
isNormalUser = true;
|
|
|
|
extraGroups = [ "podman" ];
|
2020-04-24 11:49:36 +02:00
|
|
|
};
|
2022-11-06 01:28:37 +01:00
|
|
|
|
|
|
|
users.users.mallory = {
|
|
|
|
isNormalUser = true;
|
|
|
|
};
|
|
|
|
};
|
2020-04-20 10:37:53 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
testScript = ''
|
2020-04-24 11:49:36 +02:00
|
|
|
import shlex
|
|
|
|
|
|
|
|
|
2021-05-25 10:26:28 +02:00
|
|
|
def su_cmd(cmd, user = "alice"):
|
2020-04-24 11:49:36 +02:00
|
|
|
cmd = shlex.quote(cmd)
|
2021-05-25 10:26:28 +02:00
|
|
|
return f"su {user} -l -c {cmd}"
|
2020-04-24 11:49:36 +02:00
|
|
|
|
2020-04-20 10:37:53 +02:00
|
|
|
|
|
|
|
podman.wait_for_unit("sockets.target")
|
2022-11-06 01:28:37 +01:00
|
|
|
docker.wait_for_unit("sockets.target")
|
2020-04-24 11:49:36 +02:00
|
|
|
start_all()
|
|
|
|
|
2020-05-13 07:12:59 +02:00
|
|
|
with subtest("Run container as root with runc"):
|
2021-12-08 23:32:24 +01:00
|
|
|
podman.succeed("tar cv --files-from /dev/null | podman import - scratchimg")
|
2020-04-24 11:49:36 +02:00
|
|
|
podman.succeed(
|
2020-05-13 07:12:59 +02:00
|
|
|
"podman run --runtime=runc -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
|
2020-04-24 11:49:36 +02:00
|
|
|
)
|
|
|
|
podman.succeed("podman ps | grep sleeping")
|
|
|
|
podman.succeed("podman stop sleeping")
|
2020-05-13 07:12:59 +02:00
|
|
|
podman.succeed("podman rm sleeping")
|
2020-04-24 11:49:36 +02:00
|
|
|
|
2020-05-13 07:12:59 +02:00
|
|
|
with subtest("Run container as root with crun"):
|
2021-12-08 23:32:24 +01:00
|
|
|
podman.succeed("tar cv --files-from /dev/null | podman import - scratchimg")
|
2020-05-13 07:12:59 +02:00
|
|
|
podman.succeed(
|
|
|
|
"podman run --runtime=crun -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
|
|
|
|
)
|
|
|
|
podman.succeed("podman ps | grep sleeping")
|
|
|
|
podman.succeed("podman stop sleeping")
|
|
|
|
podman.succeed("podman rm sleeping")
|
|
|
|
|
2020-11-20 00:15:31 +01:00
|
|
|
with subtest("Run container as root with the default backend"):
|
2021-12-08 23:32:24 +01:00
|
|
|
podman.succeed("tar cv --files-from /dev/null | podman import - scratchimg")
|
2020-11-20 00:15:31 +01:00
|
|
|
podman.succeed(
|
|
|
|
"podman run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
|
|
|
|
)
|
|
|
|
podman.succeed("podman ps | grep sleeping")
|
|
|
|
podman.succeed("podman stop sleeping")
|
|
|
|
podman.succeed("podman rm sleeping")
|
|
|
|
|
2022-11-06 07:31:16 +01:00
|
|
|
# start systemd session for rootless
|
2021-01-19 00:16:13 +01:00
|
|
|
podman.succeed("loginctl enable-linger alice")
|
2022-11-06 07:31:16 +01:00
|
|
|
podman.succeed(su_cmd("whoami"))
|
|
|
|
podman.sleep(1)
|
2021-01-19 00:16:13 +01:00
|
|
|
|
|
|
|
with subtest("Run container rootless with runc"):
|
2021-12-08 23:32:24 +01:00
|
|
|
podman.succeed(su_cmd("tar cv --files-from /dev/null | podman import - scratchimg"))
|
2021-01-19 00:16:13 +01:00
|
|
|
podman.succeed(
|
|
|
|
su_cmd(
|
|
|
|
"podman run --runtime=runc -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
podman.succeed(su_cmd("podman ps | grep sleeping"))
|
|
|
|
podman.succeed(su_cmd("podman stop sleeping"))
|
|
|
|
podman.succeed(su_cmd("podman rm sleeping"))
|
|
|
|
|
2020-11-20 00:15:31 +01:00
|
|
|
with subtest("Run container rootless with crun"):
|
2021-12-08 23:32:24 +01:00
|
|
|
podman.succeed(su_cmd("tar cv --files-from /dev/null | podman import - scratchimg"))
|
2020-05-13 07:12:59 +02:00
|
|
|
podman.succeed(
|
|
|
|
su_cmd(
|
2020-11-20 00:15:31 +01:00
|
|
|
"podman run --runtime=crun -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
|
2020-05-13 07:12:59 +02:00
|
|
|
)
|
|
|
|
)
|
|
|
|
podman.succeed(su_cmd("podman ps | grep sleeping"))
|
|
|
|
podman.succeed(su_cmd("podman stop sleeping"))
|
|
|
|
podman.succeed(su_cmd("podman rm sleeping"))
|
|
|
|
|
2020-11-20 00:15:31 +01:00
|
|
|
with subtest("Run container rootless with the default backend"):
|
2021-12-08 23:32:24 +01:00
|
|
|
podman.succeed(su_cmd("tar cv --files-from /dev/null | podman import - scratchimg"))
|
2020-04-24 11:49:36 +02:00
|
|
|
podman.succeed(
|
|
|
|
su_cmd(
|
2020-11-20 00:15:31 +01:00
|
|
|
"podman run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
|
2020-04-24 11:49:36 +02:00
|
|
|
)
|
|
|
|
)
|
|
|
|
podman.succeed(su_cmd("podman ps | grep sleeping"))
|
|
|
|
podman.succeed(su_cmd("podman stop sleeping"))
|
2020-05-13 07:12:59 +02:00
|
|
|
podman.succeed(su_cmd("podman rm sleeping"))
|
2021-03-21 21:12:32 +01:00
|
|
|
|
|
|
|
with subtest("Run container with init"):
|
|
|
|
podman.succeed(
|
2021-12-08 23:32:24 +01:00
|
|
|
"tar cv -C ${pkgs.pkgsStatic.busybox} . | podman import - busybox"
|
2021-03-21 21:12:32 +01:00
|
|
|
)
|
|
|
|
pid = podman.succeed("podman run --rm busybox readlink /proc/self").strip()
|
|
|
|
assert pid == "1"
|
|
|
|
pid = podman.succeed("podman run --rm --init busybox readlink /proc/self").strip()
|
|
|
|
assert pid == "2"
|
2021-05-25 10:26:28 +02:00
|
|
|
|
|
|
|
with subtest("A podman member can use the docker cli"):
|
2022-11-06 01:28:37 +01:00
|
|
|
docker.succeed(su_cmd("docker version"))
|
2021-05-25 10:26:28 +02:00
|
|
|
|
|
|
|
with subtest("Run container via docker cli"):
|
2022-11-06 01:28:37 +01:00
|
|
|
docker.succeed("docker network create default")
|
|
|
|
docker.succeed("tar cv --files-from /dev/null | podman import - scratchimg")
|
|
|
|
docker.succeed(
|
2022-02-17 01:56:18 +01:00
|
|
|
"docker run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin localhost/scratchimg /bin/sleep 10"
|
2021-05-25 10:26:28 +02:00
|
|
|
)
|
2022-11-06 01:28:37 +01:00
|
|
|
docker.succeed("docker ps | grep sleeping")
|
|
|
|
docker.succeed("podman ps | grep sleeping")
|
|
|
|
docker.succeed("docker stop sleeping")
|
|
|
|
docker.succeed("docker rm sleeping")
|
|
|
|
docker.succeed("docker network rm default")
|
2021-05-25 10:26:28 +02:00
|
|
|
|
|
|
|
with subtest("A podman non-member can not use the docker cli"):
|
2022-11-06 01:28:37 +01:00
|
|
|
docker.fail(su_cmd("docker version", user="mallory"))
|
2021-05-25 10:26:28 +02:00
|
|
|
|
|
|
|
# TODO: add docker-compose test
|
|
|
|
|
2020-04-20 10:37:53 +02:00
|
|
|
'';
|
|
|
|
}
|
|
|
|
)
|