|
| 1 | +#!/usr/bin/env bash |
| 2 | +set -euo pipefail |
| 3 | + |
| 4 | +ROOT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)" |
| 5 | +GUARD="${ROOT_DIR}/.github/scripts/verify-release-source.sh" |
| 6 | +TMP_DIR="$(mktemp -d)" |
| 7 | +trap 'rm -rf "${TMP_DIR}"' EXIT |
| 8 | + |
| 9 | +pass_count=0 |
| 10 | +fail() { |
| 11 | + echo "not ok - $1" >&2 |
| 12 | + exit 1 |
| 13 | +} |
| 14 | + |
| 15 | +pass() { |
| 16 | + pass_count=$((pass_count + 1)) |
| 17 | + echo "ok ${pass_count} - $1" |
| 18 | +} |
| 19 | + |
| 20 | +git_init_repo() { |
| 21 | + local repo="$1" |
| 22 | + git -C "$repo" config user.email smoke@example.com |
| 23 | + git -C "$repo" config user.name "Smoke Test" |
| 24 | +} |
| 25 | + |
| 26 | +REMOTE="${TMP_DIR}/remote.git" |
| 27 | +WORK="${TMP_DIR}/work" |
| 28 | +STALE="${TMP_DIR}/stale" |
| 29 | + |
| 30 | +git init -q --bare -b main "$REMOTE" |
| 31 | +git clone -q "$REMOTE" "$WORK" 2>/dev/null |
| 32 | +git_init_repo "$WORK" |
| 33 | + |
| 34 | +printf 'first\n' > "${WORK}/source.txt" |
| 35 | +git -C "$WORK" add source.txt |
| 36 | +git -C "$WORK" commit -q -m 'fix: first releasable change' |
| 37 | +git -C "$WORK" push -q origin main |
| 38 | +FIRST_SHA="$(git -C "$WORK" rev-parse HEAD)" |
| 39 | + |
| 40 | +git clone -q "$REMOTE" "$STALE" |
| 41 | + |
| 42 | +printf 'second\n' > "${WORK}/source.txt" |
| 43 | +git -C "$WORK" commit -q -am 'fix: intended merged change' |
| 44 | +git -C "$WORK" push -q origin main |
| 45 | +SECOND_SHA="$(git -C "$WORK" rev-parse HEAD)" |
| 46 | + |
| 47 | +if ( cd "$STALE" && bash "$GUARD" --remote-ref=origin/main ) >"${TMP_DIR}/stale-checkout.out" 2>"${TMP_DIR}/stale-checkout.err"; then |
| 48 | + fail 'stale checkout guard should fail' |
| 49 | +fi |
| 50 | + |
| 51 | +if ! grep -q "HEAD=${FIRST_SHA}" "${TMP_DIR}/stale-checkout.err"; then |
| 52 | + fail 'stale checkout error includes HEAD SHA' |
| 53 | +fi |
| 54 | + |
| 55 | +if ! grep -q "origin/main=${SECOND_SHA}" "${TMP_DIR}/stale-checkout.err"; then |
| 56 | + fail 'stale checkout error includes origin/main SHA' |
| 57 | +fi |
| 58 | + |
| 59 | +if ! grep -q 'behind=1' "${TMP_DIR}/stale-checkout.err"; then |
| 60 | + fail 'stale checkout error includes behind count' |
| 61 | +fi |
| 62 | + |
| 63 | +pass 'stale checkout fails with actionable SHA and behind evidence' |
| 64 | + |
| 65 | +git -C "$STALE" fetch -q origin main --tags |
| 66 | +git -C "$STALE" reset -q --hard origin/main |
| 67 | +git -C "$STALE" tag v1.0.0 |
| 68 | + |
| 69 | +( cd "$STALE" && bash "$GUARD" --remote-ref=origin/main --tag=v1.0.0 --expected-source="$SECOND_SHA" ) >"${TMP_DIR}/fresh-tag.out" 2>"${TMP_DIR}/fresh-tag.err" |
| 70 | + |
| 71 | +if ! grep -q "tag v1.0.0 ${SECOND_SHA}" "${TMP_DIR}/fresh-tag.out"; then |
| 72 | + fail 'fresh tag output includes tag SHA' |
| 73 | +fi |
| 74 | + |
| 75 | +pass 'fresh tag containing origin/main passes with tag SHA evidence' |
| 76 | + |
| 77 | +git -C "$STALE" tag -f v0.9.0 "$FIRST_SHA" >/dev/null |
| 78 | + |
| 79 | +if ( cd "$STALE" && bash "$GUARD" --remote-ref=origin/main --tag=v0.9.0 --expected-source="$SECOND_SHA" ) >"${TMP_DIR}/stale-tag.out" 2>"${TMP_DIR}/stale-tag.err"; then |
| 80 | + fail 'stale tag guard should fail' |
| 81 | +fi |
| 82 | + |
| 83 | +if ! grep -q "v0.9.0 (${FIRST_SHA})" "${TMP_DIR}/stale-tag.err"; then |
| 84 | + fail 'stale tag error includes tag SHA' |
| 85 | +fi |
| 86 | + |
| 87 | +if ! grep -q "expected source ${SECOND_SHA}" "${TMP_DIR}/stale-tag.err"; then |
| 88 | + fail 'stale tag error includes expected source SHA' |
| 89 | +fi |
| 90 | + |
| 91 | +if ! grep -q 'behind=1' "${TMP_DIR}/stale-tag.err"; then |
| 92 | + fail 'stale tag error includes behind count' |
| 93 | +fi |
| 94 | + |
| 95 | +pass 'stale tag fails with tag SHA, origin/main SHA, and behind evidence' |
| 96 | + |
| 97 | +echo "${pass_count}/${pass_count} passed" |
0 commit comments