mirror of
https://github.com/DeterminateSystems/magic-nix-cache-action.git
synced 2025-01-10 14:12:03 +01:00
9ab3ce70d6
* Update `detsys-ts` for: `Merge pull request #67 from DeterminateSystems/allow-obliterating-id-token-privs` (`4280bc94c9545f31ccf08001cc16f20ccb91b770`) * Update the defaults / docs on the use-flakehub and use-gha-cache options * Support the MNC trinary, to allow GHA cache to turn off if FHC is enabled * let's go? * arg, you can't parameterize the permissions * don't fail fast * Maybe if we bust the token sooner..? * Clearer job names * Debug... * ? * ...? * ? * fancy it up * more seed * Test against determinate too * ... * derp, obliterate * Identify the failed-to-setup FHC as not being enabled * Don't fail on github if the cache is throttled * derp * Add a success job for the ci workflow --------- Co-authored-by: grahamc <76716+grahamc@users.noreply.github.com>
106 lines
2.7 KiB
Bash
Executable file
106 lines
2.7 KiB
Bash
Executable file
#! /usr/bin/env bash
|
|
|
|
set -e
|
|
set -ux
|
|
|
|
seed="$(date)-$RANDOM"
|
|
|
|
log="${MAGIC_NIX_CACHE_DAEMONDIR}/daemon.log"
|
|
|
|
flakehub_binary_cache=https://cache.flakehub.com
|
|
gha_binary_cache=http://127.0.0.1:37515
|
|
|
|
is_gh_throttled() {
|
|
grep 'GitHub Actions Cache throttled Magic Nix Cache' "${log}"
|
|
}
|
|
|
|
# Check that the action initialized correctly.
|
|
if [ "$EXPECT_FLAKEHUB" == "true" ]; then
|
|
grep 'FlakeHub cache is enabled' "${log}"
|
|
grep 'Using cache' "${log}"
|
|
else
|
|
grep 'FlakeHub cache is disabled' "${log}" \
|
|
|| grep 'FlakeHub cache initialization failed:' "${log}"
|
|
fi
|
|
|
|
if [ "$EXPECT_GITHUB_CACHE" == "true" ]; then
|
|
grep 'GitHub Action cache is enabled' "${log}"
|
|
else
|
|
grep 'Native GitHub Action cache is disabled' "${log}"
|
|
fi
|
|
|
|
# Build something.
|
|
outpath=$(nix-build .github/workflows/cache-tester.nix --argstr seed "$seed")
|
|
|
|
# Wait until it has been pushed succesfully.
|
|
if [ "$EXPECT_FLAKEHUB" == "true" ]; then
|
|
found=
|
|
for ((i = 0; i < 60; i++)); do
|
|
sleep 1
|
|
if grep "✅ $(basename "${outpath}")" "${log}"; then
|
|
found=1
|
|
break
|
|
fi
|
|
done
|
|
if [[ -z $found ]]; then
|
|
echo "FlakeHub push did not happen." >&2
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
if [ "$EXPECT_GITHUB_CACHE" == "true" ]; then
|
|
found=
|
|
for ((i = 0; i < 60; i++)); do
|
|
sleep 1
|
|
if grep "Uploaded '${outpath}' to the GitHub Action Cache" "${log}"; then
|
|
found=1
|
|
break
|
|
fi
|
|
done
|
|
if [[ -z $found ]]; then
|
|
echo "GitHub Actions Cache push did not happen." >&2
|
|
|
|
if ! is_gh_throttled; then
|
|
exit 1
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
if [ "$EXPECT_FLAKEHUB" == "true" ]; then
|
|
# Check the FlakeHub binary cache to see if the path is really there.
|
|
nix path-info --store "${flakehub_binary_cache}" "${outpath}"
|
|
fi
|
|
|
|
if [ "$EXPECT_GITHUB_CACHE" == "true" ] && ! is_gh_throttled; then
|
|
# Check the GitHub binary cache to see if the path is really there.
|
|
nix path-info --store "${gha_binary_cache}" "${outpath}"
|
|
fi
|
|
|
|
rm ./result
|
|
nix store delete "${outpath}"
|
|
if [ -f "$outpath" ]; then
|
|
echo "$outpath still exists? can't test"
|
|
exit 1
|
|
fi
|
|
|
|
rm -rf ~/.cache/nix
|
|
|
|
echo "-------"
|
|
echo "Trying to substitute the build again..."
|
|
echo "if it fails, the cache is broken."
|
|
|
|
if [ "$EXPECT_FLAKEHUB" == "true" ]; then
|
|
# Check the FlakeHub binary cache to see if the path is really there.
|
|
nix path-info --store "${flakehub_binary_cache}" "${outpath}"
|
|
fi
|
|
|
|
if [ "$EXPECT_GITHUB_CACHE" == "true" ] && ! is_gh_throttled; then
|
|
# Check the FlakeHub binary cache to see if the path is really there.
|
|
nix path-info --store "${gha_binary_cache}" "${outpath}"
|
|
fi
|
|
|
|
if ([ "$EXPECT_GITHUB_CACHE" == "true" ] && ! is_gh_throttled) || [ "$EXPECT_FLAKEHUB" == "true" ]; then
|
|
nix-store --realize -vvvvvvvv "$outpath"
|
|
fi
|