From da3aa9a273544efc8d13864439cf73c35d30855c Mon Sep 17 00:00:00 2001 From: aszlig Date: Tue, 21 Nov 2017 07:42:53 +0100 Subject: tests: Add simple test for buildSandbox This is only a very rudimentary test of the sandbox implementation, but it already serves as a series of regression test for a few problems I ran into so far. Signed-off-by: aszlig --- tests/default.nix | 1 + tests/games/sandbox.nix | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 43 insertions(+) create mode 100644 tests/games/sandbox.nix (limited to 'tests') diff --git a/tests/default.nix b/tests/default.nix index 31fa8154..0d03bc62 100644 --- a/tests/default.nix +++ b/tests/default.nix @@ -7,6 +7,7 @@ let in { games = { + sandbox = callTest ./games/sandbox.nix; starbound = callTest ./games/starbound.nix; }; programs = { diff --git a/tests/games/sandbox.nix b/tests/games/sandbox.nix new file mode 100644 index 00000000..98d29870 --- /dev/null +++ b/tests/games/sandbox.nix @@ -0,0 +1,42 @@ +{ + name = "sandbox"; + + machine = { pkgs, lib, ... }: { + nixpkgs.config.vuizvui.games = {}; + system.activationScripts.inject-link = '' + ln -svf ${pkgs.hello} /run/foo-test-sandbox + ln -svf ${pkgs.gnused} /run/bar-test-sandbox + ln -svf ${pkgs.gnugrep} /run/baz-test-sandbox + ''; + environment.sessionVariables.COLLECT_ME = [ + "/run/foo-test-sandbox" + "/run/bar-test-sandbox" + "/run/baz-test-sandbox" + ]; + environment.systemPackages = let + testProgram = pkgs.writeScriptBin "test-sandbox" '' + #!${pkgs.stdenv.shell} -ex + ! echo foo | grep -qF foo + export PATH=/run/baz-test-sandbox/bin + echo foo > /home/foo/existing/bar + test ! -d /home/foo/nonexisting + /run/foo-test-sandbox/bin/hello + echo aaa | /run/bar-test-sandbox/bin/sed -e 's/a/b/g' + ''; + in lib.singleton (pkgs.vuizvui.games.buildSandbox testProgram { + paths.required = [ "/home/foo/existing" ]; + paths.wanted = [ "/home/foo/nonexisting" ]; + paths.runtimeVars = [ "COLLECT_ME" ]; + }); + users.users.foo.isNormalUser = true; + }; + + testScript = '' + $machine->waitForUnit('multi-user.target'); + $machine->succeed('su - -c test-sandbox foo >&2'); + + $machine->succeed('test -d /home/foo/existing'); + $machine->succeed('grep -qF foo /home/foo/existing/bar'); + $machine->fail('test -d /home/foo/nonexisting'); + ''; +} -- cgit 1.4.1