diff options
author | Matthew Bauer <mjbauer95@gmail.com> | 2021-03-09 11:40:16 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-09 11:40:16 -0600 |
commit | d5fd0f4745d834f7ac7049a0eb7e212ce9c7ef47 (patch) | |
tree | dd14d3f4f3bfa4780f32ce1b57d0d505d024388c /tests/ca/build.sh | |
parent | 4fefe26717fa70828e3f524e43c76e3f7b7a09b0 (diff) | |
parent | 1c0e3e453d41b869e4ac7e25dc1c00c349a7c411 (diff) |
Merge branch 'master' into cross-jobs
Diffstat (limited to 'tests/ca/build.sh')
-rw-r--r-- | tests/ca/build.sh | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/tests/ca/build.sh b/tests/ca/build.sh new file mode 100644 index 000000000..35bf1dcf7 --- /dev/null +++ b/tests/ca/build.sh @@ -0,0 +1,69 @@ +#!/usr/bin/env bash + +source common.sh + +drv=$(nix-instantiate --experimental-features ca-derivations ./content-addressed.nix -A rootCA --arg seed 1) +nix --experimental-features 'nix-command ca-derivations' show-derivation --derivation "$drv" --arg seed 1 + +buildAttr () { + local derivationPath=$1 + local seedValue=$2 + shift; shift + local args=("--experimental-features" "ca-derivations" "./content-addressed.nix" "-A" "$derivationPath" --arg seed "$seedValue" "--no-out-link") + args+=("$@") + nix-build "${args[@]}" +} + +testRemoteCache () { + clearCache + local outPath=$(buildAttr dependentNonCA 1) + nix copy --to file://$cacheDir $outPath + clearStore + buildAttr dependentNonCA 1 --option substituters file://$cacheDir --no-require-sigs |& (! grep "building dependent-non-ca") +} + +testDeterministicCA () { + [[ $(buildAttr rootCA 1) = $(buildAttr rootCA 2) ]] +} + +testCutoffFor () { + local out1 out2 + out1=$(buildAttr $1 1) + # The seed only changes the root derivation, and not it's output, so the + # dependent derivations should only need to be built once. + buildAttr rootCA 2 + out2=$(buildAttr $1 2 -j0) + test "$out1" == "$out2" +} + +testCutoff () { + # Don't directly build depenentCA, that way we'll make sure we dodn't rely on + # dependent derivations always being already built. + #testDerivation dependentCA + testCutoffFor transitivelyDependentCA + testCutoffFor dependentNonCA + testCutoffFor dependentFixedOutput +} + +testGC () { + nix-instantiate --experimental-features ca-derivations ./content-addressed.nix -A rootCA --arg seed 5 + nix-collect-garbage --experimental-features ca-derivations --option keep-derivations true + clearStore + buildAttr rootCA 1 --out-link $TEST_ROOT/rootCA + nix-collect-garbage --experimental-features ca-derivations + buildAttr rootCA 1 -j0 +} + +testNixCommand () { + clearStore + nix build --experimental-features 'nix-command ca-derivations' --file ./content-addressed.nix --no-link +} + +# Disabled until we have it properly working +# testRemoteCache +clearStore +testDeterministicCA +clearStore +testCutoff +testGC +testNixCommand |