···
1
-
# This test runs podman and checks if simple container starts
import ../make-test-python.nix (
···
14
-
virtualisation.podman.enable = true;
9
+
podman = { pkgs, ... }: {
10
+
virtualisation.podman.enable = true;
16
-
# To test docker socket support
17
-
virtualisation.podman.dockerSocket.enable = true;
18
-
environment.systemPackages = [
12
+
users.users.alice = {
13
+
isNormalUser = true;
16
+
docker = { pkgs, ... }: {
17
+
virtualisation.podman.enable = true;
19
+
virtualisation.podman.dockerSocket.enable = true;
22
-
users.users.alice = {
23
-
isNormalUser = true;
24
-
home = "/home/alice";
25
-
description = "Alice Foobar";
26
-
extraGroups = [ "podman" ];
21
+
environment.systemPackages = [
29
-
users.users.mallory = {
30
-
isNormalUser = true;
31
-
home = "/home/mallory";
32
-
description = "Mallory Foobar";
25
+
users.users.alice = {
26
+
isNormalUser = true;
27
+
extraGroups = [ "podman" ];
30
+
users.users.mallory = {
31
+
isNormalUser = true;
···
podman.wait_for_unit("sockets.target")
46
+
docker.wait_for_unit("sockets.target")
with subtest("Run container as root with runc"):
···
with subtest("A podman member can use the docker cli"):
123
-
podman.succeed(su_cmd("docker version"))
122
+
docker.succeed(su_cmd("docker version"))
with subtest("Run container via docker cli"):
126
-
podman.succeed("docker network create default")
127
-
podman.succeed("tar cv --files-from /dev/null | podman import - scratchimg")
125
+
docker.succeed("docker network create default")
126
+
docker.succeed("tar cv --files-from /dev/null | podman import - scratchimg")
"docker run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin localhost/scratchimg /bin/sleep 10"
131
-
podman.succeed("docker ps | grep sleeping")
132
-
podman.succeed("podman ps | grep sleeping")
133
-
podman.succeed("docker stop sleeping")
134
-
podman.succeed("docker rm sleeping")
135
-
podman.succeed("docker network rm default")
130
+
docker.succeed("docker ps | grep sleeping")
131
+
docker.succeed("podman ps | grep sleeping")
132
+
docker.succeed("docker stop sleeping")
133
+
docker.succeed("docker rm sleeping")
134
+
docker.succeed("docker network rm default")
with subtest("A podman non-member can not use the docker cli"):
138
-
podman.fail(su_cmd("docker version", user="mallory"))
137
+
docker.fail(su_cmd("docker version", user="mallory"))
# TODO: add docker-compose test