From 432739b3e950f3ee33d4f083343b28f7755d0861 Mon Sep 17 00:00:00 2001 From: Ben Sima Date: Wed, 3 Apr 2024 14:54:37 -0400 Subject: Enable CI for every commit Uses git test to run CI on every commit before push. --- .envrc | 1 + Biz/Ci.sh | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++ Biz/Ide/hooks/pre-push | 57 +----------------------------------------------- 3 files changed, 61 insertions(+), 56 deletions(-) create mode 100755 Biz/Ci.sh diff --git a/.envrc b/.envrc index c816943..05b10d0 100644 --- a/.envrc +++ b/.envrc @@ -42,6 +42,7 @@ git config --local branchless.test.alias.bild 'CODEROOT=$PWD bild **/*' git config --local branchless.test.alias.lint 'CODEROOT=$PWD bild Biz/Lint.hs && _/bin/lint **/*' git config --local branchless.test.alias.lintfix 'CODEROOT=$PWD bild Biz/Lint.hs && _/bin/lint --fix **/*' + git config --local branchless.test.alias.ci 'CODEROOT=$PWD Biz/Ci.sh' # # load local settings . ./.envrc.local diff --git a/Biz/Ci.sh b/Biz/Ci.sh new file mode 100755 index 0000000..9dbfd5b --- /dev/null +++ b/Biz/Ci.sh @@ -0,0 +1,59 @@ +#!/usr/bin/env bash +# +# A simple ci that saves its results in a git note, formatted according to +# RFC-2822, more or less. +# +# To run this manually, exec the script. It will by default run the tests for +# HEAD, whatever you currently have checked out. +# +# It would be cool to use a zero-knowledge proof mechanism here to prove that +# so-and-so ran the tests, but I'll have to research how to do that. +# +## + set -uo pipefail + [[ -n $(git status -s) ]] && { echo fail: dirty worktree; exit 1; } +## + at=$(date -R) + user=$(git config --get user.name) + mail=$(git config --get user.email) +## + commit=$(git notes --ref=ci show HEAD || true) + if [[ -n "$commit" ]] + then + if grep -q "Lint-is: good" <<< "$commit" + then + exit 0 + fi + if grep -q "Test-is: good" <<< "$commit" + then + exit 0 + fi + fi +## + runlint="$CODEROOT"/_/bin/lint + [[ ! -f "$runlint" ]] && bild "${BILD_ARGS:-""}" "${CODEROOT:?}"/Biz/Lint.hs + if "$runlint" "${CODEROOT:?}"/**/* + then + lint_result="good" + else + lint_result="fail" + exit 1 + fi +## + if bild "${BILD_ARGS:-""}" --test "${CODEROOT:?}"/**/* + then + test_result="good" + else + test_result="fail" + exit 1 + fi +## + read -r -d '' note < +Test-at: $at +EOF +## + git notes --ref=ci append -m "$note" +## diff --git a/Biz/Ide/hooks/pre-push b/Biz/Ide/hooks/pre-push index eccd4cd..1a47699 100755 --- a/Biz/Ide/hooks/pre-push +++ b/Biz/Ide/hooks/pre-push @@ -1,57 +1,2 @@ #!/usr/bin/env bash -# -# A simple ci that saves its results in a git note, formatted according to -# RFC-2822, more or less. -# -# To run this manually, exec the script. It will by default run the tests for -# HEAD, whatever you currently have checked out. -# -# It would be cool to use a zero-knowledge proof mechanism here to prove that -# so-and-so ran the tests, but I'll have to research how to do that. -# -## - set -uo pipefail - [[ -n $(git status -s) ]] && { echo fail: dirty worktree; exit 1; } -## - at=$(date -R) - user=$(git config --get user.name) - mail=$(git config --get user.email) -## - commit=$(git notes --ref=ci show HEAD || true) - if [[ -n "$commit" ]] - then - if grep -q "Lint-is: good" <<< "$commit" - then - exit 0 - fi - if grep -q "Test-is: good" <<< "$commit" - then - exit 0 - fi - fi -## - if lint "${CODEROOT:?}"/**/* - then - lint_result="good" - else - lint_result="fail" - exit 1 - fi -## - if bild "${BILD_ARGS:-""}" --test "${CODEROOT:?}"/**/* - then - test_result="good" - else - test_result="fail" - exit 1 - fi -## - read -r -d '' note < -Test-at: $at -EOF -## - git notes --ref=ci append -m "$note" -## +git test run --command ci origin/live..HEAD --no-cache --jobs 5 -- cgit v1.2.3