Skip to content

Commit afb5944

Browse files
authored
Cachix does not respond to pin requests (#133)
- To work around this. Introducing a script and WF update to check through API if the pin was made and the artifacts were uploaded.
1 parent 10a3728 commit afb5944

File tree

3 files changed

+116
-0
lines changed

3 files changed

+116
-0
lines changed
Lines changed: 86 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,86 @@
1+
#!/usr/bin/env bash
2+
set -euo pipefail
3+
4+
# Kup relies on cachix registry k-framework-binary.
5+
CACHE="k-framework-binary"
6+
OWNER_REPO="${OWNER_REPO:-$(git remote get-url origin | sed -E 's#(git@github.com:|https://github.com/)##; s#\.git$##')}"
7+
REV="${REV:-${GITHUB_SHA:-$(git rev-parse HEAD)}}"
8+
UNAME_S="$(uname -s)"
9+
UNAME_M="$(uname -m)"
10+
case "${UNAME_S}-${UNAME_M}" in
11+
Linux-x86_64) SYSTEM="x86_64-linux" ;;
12+
Linux-aarch64 | Linux-arm64) SYSTEM="aarch64-linux" ;;
13+
Darwin-x86_64) SYSTEM="x86_64-darwin" ;;
14+
Darwin-arm64) SYSTEM="aarch64-darwin" ;;
15+
*)
16+
echo "Unsupported platform: ${UNAME_S}-${UNAME_M}" >&2
17+
exit 1
18+
;;
19+
esac
20+
PIN_API_URL="https://app.cachix.org/api/v1/cache/${CACHE}/pin"
21+
CHECK_PACKAGES=(stable-mir-json)
22+
23+
SUMMARY="${GITHUB_STEP_SUMMARY:-/dev/stdout}"
24+
25+
{
26+
echo "## Cachix Publish Summary"
27+
echo "CACHE: $CACHE"
28+
echo "OWNER_REPO: $OWNER_REPO"
29+
echo "REV: $REV"
30+
echo "SYSTEM: $SYSTEM"
31+
echo "PACKAGES: ${CHECK_PACKAGES[*]}"
32+
} >> "$SUMMARY"
33+
34+
# Verify push + pin together for each package. Both can become visible with delay.
35+
PIN_VISIBILITY_TIMEOUT_SECONDS=120 # 2 minutes
36+
PIN_VISIBILITY_INTERVAL_SECONDS=5 # 5 seconds
37+
PIN_VISIBILITY_ATTEMPTS=$((PIN_VISIBILITY_TIMEOUT_SECONDS / PIN_VISIBILITY_INTERVAL_SECONDS))
38+
for i in $(seq 1 "$PIN_VISIBILITY_ATTEMPTS"); do
39+
PIN_JSON="$(curl -fsSL "${PIN_API_URL}?q=${REV}")"
40+
ALL_OK=1
41+
42+
for PKG in "${CHECK_PACKAGES[@]}"; do
43+
KEY="github:${OWNER_REPO}/${REV}#packages.${SYSTEM}.${PKG}"
44+
STORE_PATH="$(
45+
echo "$PIN_JSON" \
46+
| jq -r --arg k "$KEY" 'map(select(.name == $k)) | first | (.lastRevision.storePath // .storePath // .store_path // .path // "")'
47+
)"
48+
if [ -z "$STORE_PATH" ]; then
49+
PIN_STATUS="pin-missing"
50+
PUSH_STATUS="000"
51+
ALL_OK=0
52+
{
53+
echo "key-${PKG}: ${KEY}"
54+
echo "pin-status-${PKG}: ${PIN_STATUS}"
55+
echo "push-http-${PKG}: ${PUSH_STATUS}"
56+
}
57+
continue
58+
fi
59+
60+
PIN_STATUS="pin-ok"
61+
HASH="$(basename "$STORE_PATH" | cut -d- -f1)"
62+
PUSH_NARINFO_URL="https://${CACHE}.cachix.org/${HASH}.narinfo"
63+
PUSH_STATUS="$(curl -sS -o /dev/null -w '%{http_code}' "$PUSH_NARINFO_URL")" || PUSH_STATUS="000"
64+
if [ "$PUSH_STATUS" != "200" ]; then
65+
ALL_OK=0
66+
fi
67+
68+
{
69+
echo "key-${PKG}: ${KEY}"
70+
echo "store-path-${PKG}: ${STORE_PATH}"
71+
echo "pin-status-${PKG}: ${PIN_STATUS}"
72+
echo "push-http-${PKG}: ${PUSH_STATUS}"
73+
}
74+
done
75+
76+
if [ "$ALL_OK" = "1" ]; then
77+
echo "cachix-status: push-and-pin-ok-for-all-packages" >> "$SUMMARY"
78+
exit 0
79+
fi
80+
81+
echo "cachix-check-attempt-${i}: not-ready, retrying in ${PIN_VISIBILITY_INTERVAL_SECONDS}s"
82+
sleep "$PIN_VISIBILITY_INTERVAL_SECONDS"
83+
done
84+
85+
echo "cachix-status: push-or-pin-missing-after-${PIN_VISIBILITY_TIMEOUT_SECONDS}s-for-at-least-one-package" >> "$SUMMARY"
86+
exit 1

.github/workflows/master.yml

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -80,3 +80,5 @@ jobs:
8080
script: |
8181
export PATH="$(nix build github:runtimeverification/kup --no-link --json | jq -r '.[].outputs | to_entries[].value')/bin:$PATH"
8282
kup publish k-framework-binary .#stable-mir-json --keep-days 180
83+
84+
bash .github/scripts/check-cachix-pin.sh
Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
name: 'Test Cachix Pin'
2+
3+
on:
4+
workflow_dispatch:
5+
inputs:
6+
ref:
7+
description: 'Git ref (tag or SHA) of an existing release to verify'
8+
required: true
9+
type: string
10+
11+
jobs:
12+
verify-cachix-pin:
13+
name: 'Verify Cachix Pin'
14+
runs-on: [self-hosted, linux, normal]
15+
steps:
16+
- name: 'Check out code'
17+
uses: actions/checkout@v4
18+
19+
- name: 'Verify cachix publish and pin'
20+
uses: workflow/nix-shell-action@v3
21+
env:
22+
CACHIX_AUTH_TOKEN: '${{ secrets.CACHIX_PRIVATE_KFB_TOKEN }}'
23+
GC_DONT_GC: '1'
24+
OWNER_REPO: '${{ github.repository }}'
25+
REV: '${{ inputs.ref }}'
26+
with:
27+
packages: jq
28+
script: bash .github/scripts/check-cachix-pin.sh

0 commit comments

Comments
 (0)