diff options
author | Nullptrderef <nullptrderef@proton.me> | 2024-06-16 13:56:11 +0200 |
---|---|---|
committer | Nullptrderef <nullptrderef@proton.me> | 2024-06-16 13:56:11 +0200 |
commit | 3cbfa7ab59d37b53724c15fed55a4880745db6a6 (patch) | |
tree | cf0e9b5ad27b04be38bf63f9d8092bec1d122ad5 /contrib/ci/targets/debian | |
parent | ea28f2d34f308f812076e0128b1799acf8c686dd (diff) | |
download | exchange-3cbfa7ab59d37b53724c15fed55a4880745db6a6.tar.xz |
generate ci targets
Diffstat (limited to 'contrib/ci/targets/debian')
-rw-r--r-- | contrib/ci/targets/debian/Containerfile | 68 | ||||
-rwxr-xr-x | contrib/ci/targets/debian/build/build.sh | 14 | ||||
-rwxr-xr-x | contrib/ci/targets/debian/build/job.sh | 6 | ||||
-rw-r--r-- | contrib/ci/targets/debian/deb-package/install-fix.patch | 13 | ||||
-rwxr-xr-x | contrib/ci/targets/debian/deb-package/job.sh | 23 | ||||
-rwxr-xr-x | contrib/ci/targets/debian/deb-package/version.sh | 17 | ||||
-rw-r--r-- | contrib/ci/targets/debian/deploy-package/config.ini | 5 | ||||
-rwxr-xr-x | contrib/ci/targets/debian/deploy-package/job.sh | 14 | ||||
-rwxr-xr-x | contrib/ci/targets/debian/setup-job.sh | 50 |
9 files changed, 210 insertions, 0 deletions
diff --git a/contrib/ci/targets/debian/Containerfile b/contrib/ci/targets/debian/Containerfile new file mode 100644 index 000000000..a7fe8a3ac --- /dev/null +++ b/contrib/ci/targets/debian/Containerfile @@ -0,0 +1,68 @@ +FROM docker.io/library/debian:bookworm + +ENV DEBIAN_FRONTEND=noninteractive + +RUN apt-get update -yqq && \ + apt-get install -yqq \ + autoconf \ + autopoint \ + curl \ + bash \ + coreutils \ + git \ + libcurl4-gnutls-dev \ + libgcrypt-dev \ + libidn11-dev \ + libjansson-dev \ + libmicrohttpd-dev \ + libpq-dev \ + libqrencode-dev \ + libsodium-dev \ + libtool \ + libunistring-dev \ + make \ + pkg-config \ + python3-pip \ + python3-sphinx \ + python3-sphinx-rtd-theme \ + recutils \ + texinfo \ + zlib1g-dev \ + # For mustach testing (optional) \ + libjson-c-dev \ + # Debian packaging tools \ + po-debconf \ + build-essential \ + debhelper-compat \ + devscripts \ + git-buildpackage \ + # Documentation dependencies \ + doxygen \ + graphviz \ + pandoc \ + # Test suite dependencies \ + jq \ + postgresql \ + sudo \ + wget + +# Install Taler (and friends) packages +RUN curl -sS https://deb.taler.net/apt-nightly/taler-bookworm-ci.sources \ + | tee /etc/apt/sources.list.d/taler-bookworm-ci.sources + +RUN echo '\ +Package: * \n\ +Pin: origin "deb.taler.net" \n\ +Pin-Priority: 999' > /etc/apt/preferences.d/taler + +RUN cat /etc/apt/preferences.d/taler && \ + apt-get update -y && \ + apt-get install -y \ + libgnunet-dev \ + libgnunet \ + gnunet \ +&& rm -rf /var/lib/apt/lists/* + +WORKDIR /workdir + +CMD ["bash", "/workdir/ci/ci.sh"] diff --git a/contrib/ci/targets/debian/build/build.sh b/contrib/ci/targets/debian/build/build.sh new file mode 100755 index 000000000..d3fcfab85 --- /dev/null +++ b/contrib/ci/targets/debian/build/build.sh @@ -0,0 +1,14 @@ +#!/bin/bash +set -exuo pipefail + +apt-get update +apt-get upgrade -yqq + +./bootstrap +./configure CFLAGS="-ggdb -O0" \ + --enable-logging=verbose \ + --disable-doc + +nump=$(grep processor /proc/cpuinfo | wc -l) +make -j$(( $nump / 2 )) +make diff --git a/contrib/ci/targets/debian/build/job.sh b/contrib/ci/targets/debian/build/job.sh new file mode 100755 index 000000000..8d79902c5 --- /dev/null +++ b/contrib/ci/targets/debian/build/job.sh @@ -0,0 +1,6 @@ +#!/bin/bash +set -exuo pipefail + +job_dir=$(dirname "${BASH_SOURCE[0]}") + +"${job_dir}"/build.sh diff --git a/contrib/ci/targets/debian/deb-package/install-fix.patch b/contrib/ci/targets/debian/deb-package/install-fix.patch new file mode 100644 index 000000000..8334c5a7a --- /dev/null +++ b/contrib/ci/targets/debian/deb-package/install-fix.patch @@ -0,0 +1,13 @@ +diff --git a/debian/taler-exchange.install b/debian/taler-exchange.install +index 631c270b..072c6231 100644 +--- a/debian/taler-exchange.install ++++ b/debian/taler-exchange.install +@@ -36,6 +36,6 @@ usr/share/taler/exchange/templates/*.must + debian/etc-taler-exchange/* etc/ + + # Terms of service / privacy policy templates +-usr/share/taler/exchange/*.rst ++#usr/share/taler/exchange/terms/*.rst + # Translations of ToS/PP +-usr/share/taler/exchange/locale/*/LC_MESSAGES/*.po ++#usr/share/taler/exchange/terms/locale/*/LC_MESSAGES/*.po diff --git a/contrib/ci/targets/debian/deb-package/job.sh b/contrib/ci/targets/debian/deb-package/job.sh new file mode 100755 index 000000000..922f8bf63 --- /dev/null +++ b/contrib/ci/targets/debian/deb-package/job.sh @@ -0,0 +1,23 @@ +#!/bin/bash +set -exuo pipefail +# This file is in the public domain. +# Helper script to build the latest DEB packages in the container. + + +unset LD_LIBRARY_PATH + +# Install build-time dependencies. +# Update apt cache first +apt-get update +apt-get upgrade -y +mk-build-deps --install --tool='apt-get -o Debug::pkgProblemResolver=yes --no-install-recommends --yes' debian/control + +export VERSION="$(./contrib/ci/jobs/4-deb-package/version.sh)" +echo "Building package version ${VERSION}" +EMAIL=none gbp dch --dch-opt=-b --ignore-branch --debian-tag="%(version)s" --git-author --new-version="${VERSION}" +./bootstrap +dpkg-buildpackage -rfakeroot -b -uc -us + +ls -alh ../*.deb +mkdir -p /artifacts/exchange/${CI_COMMIT_REF} # Variable comes from CI environment +mv ../*.deb /artifacts/exchange/${CI_COMMIT_REF}/ diff --git a/contrib/ci/targets/debian/deb-package/version.sh b/contrib/ci/targets/debian/deb-package/version.sh new file mode 100755 index 000000000..52031b23a --- /dev/null +++ b/contrib/ci/targets/debian/deb-package/version.sh @@ -0,0 +1,17 @@ +#!/bin/sh +set -ex + +BRANCH=$(git name-rev --name-only HEAD) +if [ -z "${BRANCH}" ]; then + exit 1 +else + # "Unshallow" our checkout, but only our current branch, and exclude the submodules. + git fetch --no-recurse-submodules --tags --depth=1000 origin "${BRANCH}" + RECENT_VERSION_TAG=$(git describe --tags --match 'v*.*.*' --exclude '*-dev*' --always --abbrev=0 HEAD || exit 1) + commits="$(git rev-list ${RECENT_VERSION_TAG}..HEAD --count)" + if [ "${commits}" = "0" ]; then + git describe --tag HEAD | sed -r 's/^v//' || exit 1 + else + echo $(echo ${RECENT_VERSION_TAG} | sed -r 's/^v//')-${commits}-$(git rev-parse --short=8 HEAD) + fi +fi diff --git a/contrib/ci/targets/debian/deploy-package/config.ini b/contrib/ci/targets/debian/deploy-package/config.ini new file mode 100644 index 000000000..8d6409a6e --- /dev/null +++ b/contrib/ci/targets/debian/deploy-package/config.ini @@ -0,0 +1,5 @@ +[build] +HALT_ON_FAILURE = True +WARN_ON_FAILURE = True +CONTAINER_BUILD = False +CONTAINER_NAME = nixery.dev/shell/rsync diff --git a/contrib/ci/targets/debian/deploy-package/job.sh b/contrib/ci/targets/debian/deploy-package/job.sh new file mode 100755 index 000000000..d39cf9987 --- /dev/null +++ b/contrib/ci/targets/debian/deploy-package/job.sh @@ -0,0 +1,14 @@ +#!/bin/bash +set -exuo pipefail + +ARTIFACT_PATH="/artifacts/exchange/${CI_COMMIT_REF}/*.deb" + +RSYNC_HOST="taler.host.internal" +RSYNC_PORT=424242 +RSYNC_PATH="incoming_packages/bookworm-taler-ci/" +RSYNC_DEST="rsync://${RSYNC_HOST}/${RSYNC_PATH}" + + +rsync -vP \ + --port ${RSYNC_PORT} \ + ${ARTIFACT_PATH} ${RSYNC_DEST} diff --git a/contrib/ci/targets/debian/setup-job.sh b/contrib/ci/targets/debian/setup-job.sh new file mode 100755 index 000000000..b632eaf06 --- /dev/null +++ b/contrib/ci/targets/debian/setup-job.sh @@ -0,0 +1,50 @@ +#!/bin/bash +set -eax +# Variables passed in: +# - CI_DIR: Path to contrib/ci +# - DISTRO: Distro Name (debian) +# - CODENAME: Codename to target +# - ARCH: Architecture to use +# - OCI_IMAGE: The OCI image we're expected to target +# - DISTRO_TARGET: The TARGET dir of the current distro (targets/debian) +# - CONTAINERFILE: Our input Containerfile +# Helper Scripts: +# - mktarget: Makes a target for us + +# Generate the build target +cd "${CI_DIR}/jobs/$(mktarget 0 build)" +sed "1s|FROM .*|FROM ${OCI_IMAGE}|" "$CONTAINERFILE" > Containerfile +cp "$DISTRO_TARGET/build/build.sh" ./ +cp "$DISTRO_TARGET/build/job.sh" ./ + +if [[ "$ARCH" != "amd64" ]]; then + echo '[build] +HALT_ON_FAILURE = True +WARN_ON_FAILURE = True +CONTAINER_BUILD = True +CONTAINER_NAME = exchange:'"$ARCH"' +CONTAINER_ARCH = '"$ARCH"' +' > config.ini +fi; + +# Generate the deb-package target +cd "${CI_DIR}/jobs/$(mktarget 1 deb-package)" +sed "1s|FROM .*|FROM ${OCI_IMAGE}|" "$CONTAINERFILE" > Containerfile +cp "$DISTRO_TARGET/deb-package/version.sh" ./ +cp "$DISTRO_TARGET/deb-package/job.sh" ./ +cp "$DISTRO_TARGET/deb-package/install-fix.patch" ./ + +if [[ "$ARCH" != "amd64" ]]; then + echo '[build] +HALT_ON_FAILURE = True +WARN_ON_FAILURE = True +CONTAINER_BUILD = True +CONTAINER_NAME = exchange:'"$ARCH"' +CONTAINER_ARCH = '"$ARCH"' +' > config.ini +fi; + +# Generate the deploy-package target +cd "${CI_DIR}/jobs/$(mktarget 2 deploy-package)" +cp "$DISTRO_TARGET/deploy-package/config.ini" ./ +cp "$DISTRO_TARGET/deploy-package/job.sh" ./ |