summary refs log tree commit diff
diff options
context:
space:
mode:
authorAndrew Dunham <andrew@du.nham.ca>2019-11-26 23:01:46 -0800
committerAndrew Dunham <andrew@du.nham.ca>2019-12-03 23:55:24 -0800
commitc37902dfd196bd493fcd8fc1492790ac64be0d58 (patch)
tree8fdbb568287c180ef43f28e2df3eba604ef5f5e1
parent1f0512faf681045fc523f1ae693460c30f313a02 (diff)
downloadnixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.tar
nixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.tar.gz
nixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.tar.bz2
nixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.tar.lz
nixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.tar.xz
nixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.tar.zst
nixpkgs-c37902dfd196bd493fcd8fc1492790ac64be0d58.zip
nixosTests.gvisor: add test for gvisor and gvisor as a Docker runtime
-rw-r--r--nixos/tests/all-tests.nix1
-rw-r--r--nixos/tests/gvisor.nix49
2 files changed, 50 insertions, 0 deletions
diff --git a/nixos/tests/all-tests.nix b/nixos/tests/all-tests.nix
index df65ef249e8..fbc8b511f3b 100644
--- a/nixos/tests/all-tests.nix
+++ b/nixos/tests/all-tests.nix
@@ -103,6 +103,7 @@ in
   grafana = handleTest ./grafana.nix {};
   graphite = handleTest ./graphite.nix {};
   graylog = handleTest ./graylog.nix {};
+  gvisor = handleTest ./gvisor.nix {};
   hadoop.hdfs = handleTestOn [ "x86_64-linux" ] ./hadoop/hdfs.nix {};
   hadoop.yarn = handleTestOn [ "x86_64-linux" ] ./hadoop/yarn.nix {};
   handbrake = handleTestOn ["x86_64-linux"] ./handbrake.nix {};
diff --git a/nixos/tests/gvisor.nix b/nixos/tests/gvisor.nix
new file mode 100644
index 00000000000..4d68a1d8a5f
--- /dev/null
+++ b/nixos/tests/gvisor.nix
@@ -0,0 +1,49 @@
+# This test runs a container through gvisor and checks if simple container starts
+
+import ./make-test-python.nix ({ pkgs, ...} : {
+  name = "gvisor";
+  meta = with pkgs.stdenv.lib.maintainers; {
+    maintainers = [ andrew-d ];
+  };
+
+  nodes = {
+    gvisor =
+      { pkgs, ... }:
+        {
+          virtualisation.docker = {
+            enable = true;
+            extraOptions = "--add-runtime runsc=${pkgs.gvisor}/bin/runsc";
+          };
+
+          networking = {
+            dhcpcd.enable = false;
+            defaultGateway = "192.168.1.1";
+            interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [
+              { address = "192.168.1.2"; prefixLength = 24; }
+            ];
+          };
+        };
+    };
+
+  testScript = ''
+    start_all()
+
+    gvisor.wait_for_unit("network.target")
+    gvisor.wait_for_unit("sockets.target")
+
+    # Start by verifying that gvisor itself works
+    output = gvisor.succeed(
+        "${pkgs.gvisor}/bin/runsc -alsologtostderr do ${pkgs.coreutils}/bin/echo hello world"
+    )
+    assert output.strip() == "hello world"
+
+    # Also test the Docker runtime
+    gvisor.succeed("tar cv --files-from /dev/null | docker import - scratchimg")
+    gvisor.succeed(
+        "docker run -d --name=sleeping --runtime=runsc -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10"
+    )
+    gvisor.succeed("docker ps | grep sleeping")
+    gvisor.succeed("docker stop sleeping")
+  '';
+})
+