packages: Add E2E test for Alpine package with noarch
Refs: https://code.forgejo.org/forgejo/end-to-end/pulls/75
This commit is contained in:
parent
5bb5e037ce
commit
b563e5cd19
13 changed files with 145 additions and 6 deletions
1
packages/alpine-7.0-dev
Symbolic link
1
packages/alpine-7.0-dev
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
alpine-7.0-test
|
|
@ -0,0 +1,24 @@
|
||||||
|
# -*- mode: Shell-script; eval: (setq indent-tabs-mode 't); eval: (setq tab-width 4) -*-
|
||||||
|
# Maintainer: Dominic Meiser <git@msrd0.de>
|
||||||
|
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
|
||||||
|
"
|
3
packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173
Executable file
3
packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173
Executable file
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
echo "Hello World"
|
7
packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173.init
Executable file
7
packages/alpine-7.0-test/package-source/forgejo-2173/forgejo_2173.init
Executable file
|
@ -0,0 +1,7 @@
|
||||||
|
#!/sbin/openrc-run
|
||||||
|
|
||||||
|
command="/usr/bin/forgejo_2173"
|
||||||
|
|
||||||
|
depend() {
|
||||||
|
need net
|
||||||
|
}
|
|
@ -0,0 +1,26 @@
|
||||||
|
# -*- mode: Shell-script; eval: (setq indent-tabs-mode 't); eval: (setq tab-width 4) -*-
|
||||||
|
# Maintainer: Dominic Meiser <git@msrd0.de>
|
||||||
|
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
|
||||||
|
"
|
3
packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174
Executable file
3
packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174
Executable file
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
echo "Hello World"
|
7
packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174.init
Executable file
7
packages/alpine-7.0-test/package-source/forgejo-2174/forgejo_2174.init
Executable file
|
@ -0,0 +1,7 @@
|
||||||
|
#!/sbin/openrc-run
|
||||||
|
|
||||||
|
command="/usr/bin/forgejo_2174"
|
||||||
|
|
||||||
|
depend() {
|
||||||
|
need net
|
||||||
|
}
|
63
packages/alpine-7.0-test/test.sh
Executable file
63
packages/alpine-7.0-test/test.sh
Executable file
|
@ -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
|
|
@ -1,19 +1,24 @@
|
||||||
#!/bin/sh
|
|
||||||
# Copyright 2024 The Forgejo Authors
|
# Copyright 2024 The Forgejo Authors
|
||||||
# SPDX-License-Identifier: MIT
|
# 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
|
stop_daemon forgejo
|
||||||
reset_forgejo $PACKAGES_DIR/alpine-app.ini
|
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 token=$(cat $DIR/forgejo-curl/token)
|
||||||
local url=http://${HOST_PORT}
|
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() {
|
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
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue