1
1
Fork 0
mirror of https://github.com/NixOS/nix.git synced 2025-11-11 04:56:01 +01:00
nix/mk
John Ericson 67ab776e15 Harden tests' bash
Use `set -u` and `set -o pipefail` to catch accidental mistakes and
failures more strongly.

 - `set -u` catches the use of undefined variables
 - `set -o pipefail` catches failures (like `set -e`) earlier in the
   pipeline.

This makes the tests a bit more robust. It is nice to read code not
worrying about these spurious success paths (via uncaught) errors
undermining the tests. Indeed, I caught some bugs doing this.

There are a few tests where we run a command that should fail, and then
search its output to make sure the failure message is one that we
expect. Before, since the `grep` was the last command in the pipeline
the exit code of those failing programs was silently ignored. Now with
`set -o pipefail` it won't be, and we have to do something so the
expected failure doesn't accidentally fail the test.

To do that we use `expect` and a new `expectStderr` to check for the
exact failing exit code. See the comments on each for why.

`grep -q` is replaced with `grepQuiet`, see the comments on that
function for why.

`grep -v` when we just want the exit code is replaced with `grepInverse,
see the comments on that function for why.

`grep -q -v` together is, surprise surprise, replaced with
`grepQuietInverse`, which is both combined.

(cherry picked from commit c11836126b)
2025-02-13 11:36:30 -05:00
..
clean.mk Add 'mk/' from commit '1eff3ad37f' 2014-02-01 14:38:28 +01:00
dist.mk Add 'mk/' from commit '1eff3ad37f' 2014-02-01 14:38:28 +01:00
functions.mk Revert "Get rid of unicode quotes (#1140)" 2016-11-26 00:38:01 +01:00
install.mk Sync with make-rules repo 2014-04-03 17:37:14 +02:00
jars.mk Merge commit '36c6786036' 2014-12-14 01:47:06 +01:00
lib.mk Apply OS checks to host platform, not build 2021-07-27 08:41:57 +00:00
libraries.mk Apply OS checks to host platform, not build 2021-07-27 08:41:57 +00:00
patterns.mk Merge commit '36c6786036' 2014-12-14 01:47:06 +01:00
programs.mk mk: add support for passing LDFLAGS to libs and bins 2019-07-03 04:32:25 +02:00
run_test.sh Harden tests' bash 2025-02-13 11:36:30 -05:00
templates.mk Revert "Get rid of unicode quotes (#1140)" 2016-11-26 00:38:01 +01:00
tests.mk mk/tests.mk: document 'installcheck' in 'make help' 2025-02-13 11:36:30 -05:00
tracing.mk Merge commit 'a210c995cd' 2014-02-07 16:27:34 +01:00