about summary refs log tree commit diff
path: root/tests/shell.nix
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2017-01-03T09·08+0100
committerGitHub <noreply@github.com>2017-01-03T09·08+0100
commitae1e4dfad29e24739c7f280b1a96e16ba1b54d3a (patch)
treed25d160845444d86417c593c4309ccbdc59e2e55 /tests/shell.nix
parentb6b142b4b10552f2a2a8c904487bbd196d35a5c1 (diff)
parentb501bea25fac9c43dfd0d197e16836facd2b63a5 (diff)
Merge pull request #1169 from dezgeg/fix-shell-shebang
Fix nix-shell shebang usage
Diffstat (limited to 'tests/shell.nix')
-rw-r--r--tests/shell.nix46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/shell.nix b/tests/shell.nix
new file mode 100644
index 000000000000..ed4d6fbaaa0b
--- /dev/null
+++ b/tests/shell.nix
@@ -0,0 +1,46 @@
+{ }:
+
+with import ./config.nix;
+
+rec {
+  setupSh = builtins.toFile "setup" ''
+    export VAR_FROM_STDENV_SETUP=foo
+    for pkg in $buildInputs; do
+      export PATH=$PATH:$pkg/bin
+    done
+  '';
+
+  stdenv = mkDerivation {
+    name = "stdenv";
+    buildCommand = ''
+      mkdir -p $out
+      ln -s ${setupSh} $out/setup
+    '';
+  };
+
+  shellDrv = mkDerivation {
+    name = "shellDrv";
+    builder = "/does/not/exist";
+    VAR_FROM_NIX = "bar";
+    inherit stdenv;
+  };
+
+  # Used by nix-shell -p
+  runCommand = name: args: buildCommand: mkDerivation (args // {
+    inherit name buildCommand stdenv;
+  });
+
+  foo = runCommand "foo" {} ''
+    mkdir -p $out/bin
+    echo 'echo foo' > $out/bin/foo
+    chmod a+rx $out/bin/foo
+  '';
+
+  bar = runCommand "bar" {} ''
+    mkdir -p $out/bin
+    echo 'echo bar' > $out/bin/bar
+    chmod a+rx $out/bin/bar
+  '';
+
+  bash = shell;
+}