diff --git a/.forgejo/workflows/end-to-end.yml b/.forgejo/workflows/end-to-end.yml index 04072cd..e136f40 100644 --- a/.forgejo/workflows/end-to-end.yml +++ b/.forgejo/workflows/end-to-end.yml @@ -46,6 +46,9 @@ jobs: - uses: https://code.forgejo.org/actions/checkout@v4 - uses: ./.forgejo/prepare-end-to-end - run: su forgejo -c "./end-to-end.sh test_packages" + - name: full logs + if: always() + run: su forgejo -c "./end-to-end.sh show_logs" upgrade: name: upgrade and storage @@ -70,3 +73,6 @@ jobs: - uses: ./.forgejo/prepare-end-to-end - run: su forgejo -c "./end-to-end.sh test_upgrades" - run: su forgejo -c "./end-to-end.sh test_storage" + - name: full logs + if: always() + run: su forgejo -c "./end-to-end.sh show_logs" diff --git a/lib/lib.sh b/lib/lib.sh index fa6375f..349d1a4 100644 --- a/lib/lib.sh +++ b/lib/lib.sh @@ -298,6 +298,13 @@ function stop() { cleanup_logs } +function show_logs() { + ( + cd $DIR + grep '' *.out + ) +} + function run() { local fun=$1 shift diff --git a/packages/alpine/package-source/APKBUILD b/packages/alpine-1.21/package-source/APKBUILD similarity index 100% rename from packages/alpine/package-source/APKBUILD rename to packages/alpine-1.21/package-source/APKBUILD diff --git a/packages/alpine/package-source/forgejo_2174 b/packages/alpine-1.21/package-source/forgejo_2174 similarity index 100% rename from packages/alpine/package-source/forgejo_2174 rename to packages/alpine-1.21/package-source/forgejo_2174 diff --git a/packages/alpine/package-source/forgejo_2174.init b/packages/alpine-1.21/package-source/forgejo_2174.init similarity index 100% rename from packages/alpine/package-source/forgejo_2174.init rename to packages/alpine-1.21/package-source/forgejo_2174.init diff --git a/packages/alpine/test.sh b/packages/alpine-1.21/test.sh similarity index 100% rename from packages/alpine/test.sh rename to packages/alpine-1.21/test.sh diff --git a/packages/alpine-7.0-dev b/packages/alpine-7.0-dev new file mode 120000 index 0000000..a2389c0 --- /dev/null +++ b/packages/alpine-7.0-dev @@ -0,0 +1 @@ +alpine-7.0-test \ No newline at end of file diff --git a/packages/alpine-7.0-test/package-source/forgejo-2173/APKBUILD b/packages/alpine-7.0-test/package-source/forgejo-2173/APKBUILD new file mode 100644 index 0000000..75c9dd1 --- /dev/null +++ b/packages/alpine-7.0-test/package-source/forgejo-2173/APKBUILD @@ -0,0 +1,24 @@ +# -*- mode: Shell-script; eval: (setq indent-tabs-mode 't); eval: (setq tab-width 4) -*- +# Maintainer: Dominic Meiser +pkgname=forgejo-2173 +pkgver=1.0 +pkgrel=0 +pkgdesc="Forgejo #2173 Reproduction" +url="https://msrd0.dev/msrd0/$pkgname" +arch="noarch" +license="custom" + +subpackages="$pkgname-openrc" + +source="forgejo_2173 forgejo_2173.init" +builddir="$srcdir" + +package() { + install -D -m755 "$srcdir/forgejo_2173" "$pkgdir"/usr/bin/forgejo_2173 + install -D -m755 "$srcdir/forgejo_2173.init" "$pkgdir"/etc/init.d/forgejo_2173 +} + +sha512sums=" +651c2a816510a18981bcd45077eb5acd6e58511d641949ddc690e326b81018d851eb7f1c88e2336eada2f216606ce2aa0569eb2d02d7c423c80705cc00acf838 forgejo_2173 +abc3b1c91bd69478e8e0d46a31148bcd5b4e7838dc35e7b601673866d7e925d70ab70d63c32df98aad060134eaaa6f957691c2c4397d85af5a77f9773de21b5b forgejo_2173.init +" diff --git a/packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173 b/packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173 new file mode 100755 index 0000000..b12f87b --- /dev/null +++ b/packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173 @@ -0,0 +1,3 @@ +#!/bin/sh + +echo "Hello World" diff --git a/packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173.init b/packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173.init new file mode 100755 index 0000000..b5d66cc --- /dev/null +++ b/packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173.init @@ -0,0 +1,7 @@ +#!/sbin/openrc-run + +command="/usr/bin/forgejo_2173" + +depend() { + need net +} diff --git a/packages/alpine-7.0-test/package-source/forgejo-2174/APKBUILD b/packages/alpine-7.0-test/package-source/forgejo-2174/APKBUILD new file mode 100644 index 0000000..ce75e29 --- /dev/null +++ b/packages/alpine-7.0-test/package-source/forgejo-2174/APKBUILD @@ -0,0 +1,26 @@ +# -*- mode: Shell-script; eval: (setq indent-tabs-mode 't); eval: (setq tab-width 4) -*- +# Maintainer: Dominic Meiser +pkgname=forgejo-2174 +pkgver=1.0 +pkgrel=0 +pkgdesc="Forgejo #2174 Reproduction" +url="https://msrd0.dev/msrd0/$pkgname" +arch="x86_64" +license="custom" + +# using x86_64 instead of noarch as a workaround of +# https://codeberg.org/forgejo/forgejo/issues/2173 +subpackages="$pkgname-openrc::x86_64" + +source="forgejo_2174 forgejo_2174.init" +builddir="$srcdir" + +package() { + install -D -m755 "$srcdir/forgejo_2174" "$pkgdir"/usr/bin/forgejo_2174 + install -D -m755 "$srcdir/forgejo_2174.init" "$pkgdir"/etc/init.d/forgejo_2174 +} + +sha512sums=" +651c2a816510a18981bcd45077eb5acd6e58511d641949ddc690e326b81018d851eb7f1c88e2336eada2f216606ce2aa0569eb2d02d7c423c80705cc00acf838 forgejo_2174 +b1cba77139cdaf9e0cdd78de93becbb3891ec59646e8d2cb40620b230bd798d51e6d9c58e65b584812a6bb8eb2b9c9f89262a8700a39c62af8ec8ea09aee4e29 forgejo_2174.init +" diff --git a/packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174 b/packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174 new file mode 100755 index 0000000..b12f87b --- /dev/null +++ b/packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174 @@ -0,0 +1,3 @@ +#!/bin/sh + +echo "Hello World" diff --git a/packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174.init b/packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174.init new file mode 100755 index 0000000..06b7f20 --- /dev/null +++ b/packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174.init @@ -0,0 +1,7 @@ +#!/sbin/openrc-run + +command="/usr/bin/forgejo_2174" + +depend() { + need net +} diff --git a/packages/alpine-7.0-test/test.sh b/packages/alpine-7.0-test/test.sh new file mode 100755 index 0000000..45bb60e --- /dev/null +++ b/packages/alpine-7.0-test/test.sh @@ -0,0 +1,63 @@ +#!/bin/busybox ash +set -exuo pipefail + +forgejo_url=$1 +forgejo_token=$2 + +# initialize abuild +apk update +apk add --no-cache alpine-sdk sudo util-linux +adduser -D user -h /home/user +addgroup user abuild +echo "root ALL=(ALL) ALL" >/etc/sudoers +echo "%abuild ALL=(ALL) NOPASSWD: ALL" >>/etc/sudoers +mkdir -p /var/cache/distfiles +chgrp abuild /var/cache/distfiles +chmod 775 /var/cache/distfiles +mkdir -p "/home/user/.abuild" +echo "/home/user/.abuild/user.rsa" | abuild-keygen -i -b 4096 +echo 'PACKAGER_PRIVKEY=/home/user/.abuild/user.rsa' >/home/user/.abuild/abuild.conf +chown -R "user:user" /home/user/ + +# make sure we own the relevant directory +cp -r package-source /srv/alpine +cd /srv +mkdir packages +echo "REPODEST=/srv/packages" >>/home/user/.abuild/abuild.conf +cat /home/user/.abuild/abuild.conf +chown -R user:user alpine packages + +# build the package +sudo -u user APKBUILD=alpine/forgejo-2174/APKBUILD abuild -r + +# build the package +sudo -u user APKBUILD=alpine/forgejo-2173/APKBUILD abuild -r + +# upload new package +cd packages/alpine/x86_64/ +for file in $(find . -name '*.apk' -type f | sed -e 's,./,,'); do + # remove old package + curl \ + --fail \ + -H "Authorization: token $forgejo_token" \ + -X DELETE \ + "$forgejo_url/api/packages/root/alpine/3.19/e2e-tests/$file" \ + || true + + # upload new package + curl \ + --fail \ + -H "Authorization: token $forgejo_token" \ + -T "$file" \ + "$forgejo_url/api/packages/root/alpine/3.19/e2e-tests" +done + +# ensure that the install-if condition works as expected +apk add openrc +(cd /etc/apk/keys && curl -JO $forgejo_url/api/packages/root/alpine/key) +echo "$forgejo_url/api/packages/root/alpine/3.19/e2e-tests" >>/etc/apk/repositories +apk add forgejo-2174 forgejo-2173 +[ -e /usr/bin/forgejo_2174 ] # from the installed package +[ -e /usr/bin/forgejo_2173 ] # from the installed package +[ -e /etc/init.d/forgejo_2174 ] # from the -openrc package installed because of the install-if condition +[ -e /etc/init.d/forgejo_2173 ] # from the -openrc package installed because of the install-if condition diff --git a/packages/alpine.sh b/packages/alpine.sh index 11cb56a..b3e5b5d 100644 --- a/packages/alpine.sh +++ b/packages/alpine.sh @@ -1,19 +1,24 @@ -#!/bin/sh # Copyright 2024 The Forgejo Authors # SPDX-License-Identifier: MIT -function test_packages_alpine_v1.21() { +function test_packages_alpine_version() { + local alpine_version=$1 forgejo_version=$2 stop_daemon forgejo reset_forgejo $PACKAGES_DIR/alpine-app.ini - start_forgejo 1.21 + start_forgejo $forgejo_version - local d=$PACKAGES_DIR/alpine + local d=$PACKAGES_DIR/alpine-$forgejo_version local token=$(cat $DIR/forgejo-curl/token) local url=http://${HOST_PORT} - docker run --rm --volume $d:$d:ro --workdir $d docker.io/alpine:3.19 ash -c "./test.sh $url $token" + log_info "alpine:$alpine_version & Forgejo $forgejo_version" + docker run --rm --volume $d:$d:ro --workdir $d docker.io/alpine:$alpine_version ash -c "./test.sh $url $token" } function test_packages_alpine() { - test_packages_alpine_v1.21 + for alpine_version in 3.18 3.19 ; do + for forgejo_version in 1.21 7.0-test 7.0-dev ; do + test_packages_alpine_version $alpine_version $forgejo_version + done + done }