diff options
Diffstat (limited to 'hooks/update')
-rwxr-xr-x | hooks/update | 28 |
1 files changed, 24 insertions, 4 deletions
diff --git a/hooks/update b/hooks/update index 6dfa013..7ffc5ce 100755 --- a/hooks/update +++ b/hooks/update @@ -45,7 +45,18 @@ fi CHANNEL=$(mktemp -d 2>/dev/null || mktemp -d -t "channel") >&2 echo "The channel is in $CHANNEL." -for ref in $(guix environment --ad-hoc git -- git rev-list --reverse $span) +cat > "$CHANNEL/guix-channels-for-build.scm" <<EOF +(list (channel + (name 'guix) + (url "https://git.savannah.gnu.org/git/guix.git") + (introduction (make-channel-introduction + "9edb3f66fd807b096b48283debdcddccfea34bad" + (openpgp-fingerprint + "BBB0 2DDF 2CEA F6A8 0D1D E643 A2A0 6DF2 A33A 54FA"))))) +EOF + +for ref in $(guix time-machine -C "$CHANNEL/guix-channels-for-build.scm" \ + -- environment --ad-hoc git -- git rev-list --reverse $span) do >&2 echo "Checking new commit $ref." if test "x$ref" = "x0e29ddc3c41870e14da87770a429a94f80dd4110" @@ -53,10 +64,19 @@ do >&2 echo "This is the root, skipping." else >&2 echo "Running CI for $ref..." - guix environment --ad-hoc git -- git archive "-o" "$CHANNEL/source.tar.gz" "$ref" guix ci.scm || exit 1 - (cd "$CHANNEL" ; rm -rf "source" ; mkdir "source" ; cd "source" ; guix environment --ad-hoc tar -- tar xf ../source.tar.gz) + guix time-machine -C "$CHANNEL/guix-channels-for-build.scm" \ + -- environment --ad-hoc git \ + -- git archive "-o" "$CHANNEL/source.tar.gz" "$ref" guix ci.scm || exit 1 + (cd "$CHANNEL" ; \ + rm -rf "source" ; \ + mkdir "source" ; \ + cd "source" ; \ + guix time-machine -C "$CHANNEL/guix-channels-for-build.scm" \ + -- environment --ad-hoc tar \ + -- tar xf ../source.tar.gz) export CI_REF="$ref" - if OUTCOME=$(guix build -L "$CHANNEL/source/guix" -f "$CHANNEL/source/ci.scm") + if OUTCOME=$(guix time-machine -C "$CHANNEL/guix-channels-for-build.scm" \ + -- build -L "$CHANNEL/source/guix" -f "$CHANNEL/source/ci.scm") then >&2 echo "CI ran: $OUTCOME." else |