diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2017-01-03T09·08+0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-03T09·08+0100 |
commit | ae1e4dfad29e24739c7f280b1a96e16ba1b54d3a (patch) | |
tree | d25d160845444d86417c593c4309ccbdc59e2e55 /tests/shell.nix | |
parent | b6b142b4b10552f2a2a8c904487bbd196d35a5c1 (diff) | |
parent | b501bea25fac9c43dfd0d197e16836facd2b63a5 (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.nix | 46 |
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; +} |