feat(nix/runTestsuite): rebuild if test case list changes
If the result of the assertions changes for a successful test suite (this happens if tests are reworded, added or removed), this makes sure the no-op derivation is rebuilt. This makes sure that test suites show up in buildkite on ocassions other than channel bumps, since they are only added to the job list if their `outPath` is missing nowadays (see cl/3427). Change-Id: Ia1050cca5eeed8b7da84c40f6154b40760a3047f Reviewed-on: https://cl.tvl.fyi/c/depot/+/3536 Tested-by: BuildkiteCI Reviewed-by: Profpatsch <mail@profpatsch.de>
This commit is contained in:
parent
3a8e8120de
commit
987b9b551c
1 changed files with 5 additions and 2 deletions
|
@ -38,7 +38,7 @@ let
|
||||||
;
|
;
|
||||||
|
|
||||||
bins = depot.nix.getBins pkgs.coreutils [ "printf" ]
|
bins = depot.nix.getBins pkgs.coreutils [ "printf" ]
|
||||||
// depot.nix.getBins pkgs.s6-portable-utils [ "s6-touch" ];
|
// depot.nix.getBins pkgs.s6-portable-utils [ "s6-touch" "s6-false" ];
|
||||||
|
|
||||||
# Returns true if the given expression throws when `deepSeq`-ed
|
# Returns true if the given expression throws when `deepSeq`-ed
|
||||||
throws = expr:
|
throws = expr:
|
||||||
|
@ -157,10 +157,13 @@ let
|
||||||
};
|
};
|
||||||
goodIts = partitionTests (it: (goodIt it).asserts.err == []);
|
goodIts = partitionTests (it: (goodIt it).asserts.err == []);
|
||||||
res = goodIts itResults;
|
res = goodIts itResults;
|
||||||
|
prettyRes = lib.generators.toPretty {} res;
|
||||||
in
|
in
|
||||||
if res.err == []
|
if res.err == []
|
||||||
then depot.nix.runExecline.local "testsuite-${name}-successful" {} [
|
then depot.nix.runExecline.local "testsuite-${name}-successful" {} [
|
||||||
"importas" "out" "out"
|
"importas" "out" "out"
|
||||||
|
# force derivation to rebuild if test case list changes
|
||||||
|
"ifelse" [ bins.s6-false ] [ bins.printf "" prettyRes ]
|
||||||
"if" [ bins.printf "%s\n" "testsuite ${name} successful!" ]
|
"if" [ bins.printf "%s\n" "testsuite ${name} successful!" ]
|
||||||
bins.s6-touch "$out"
|
bins.s6-touch "$out"
|
||||||
]
|
]
|
||||||
|
@ -169,7 +172,7 @@ let
|
||||||
"if" [
|
"if" [
|
||||||
bins.printf "%s\n%s\n"
|
bins.printf "%s\n%s\n"
|
||||||
"testsuite ${name} failed!"
|
"testsuite ${name} failed!"
|
||||||
(lib.generators.toPretty {} res)
|
prettyRes
|
||||||
]
|
]
|
||||||
"exit" "1"
|
"exit" "1"
|
||||||
]);
|
]);
|
||||||
|
|
Loading…
Reference in a new issue