package: create debian package with prebuilds

The generated variants include raspi and non-raspi platforms.
This commit is contained in:
Kamil Trzcinski
2023-05-26 14:53:38 +02:00
parent d80d039f3c
commit 69584c07db
17 changed files with 257 additions and 35 deletions

View File

@ -1,26 +0,0 @@
on: [push, pull_request]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
debian_version: [buster, bullseye]
docker_arch: [amd64, arm32v7, arm64v8]
build_type: ["non-rpi", "rpi"]
exclude:
- docker_arch: amd64
build_type: rpi
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: recursive
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Build Dockerfile
run: docker build --build-arg DOCKER_ARCH --build-arg DEBIAN_VERSION --build-arg BUILD_TYPE .
env:
DEBIAN_VERSION: ${{ matrix.debian_version }}
DOCKER_ARCH: ${{ matrix.docker_arch }}/
BUILD_TYPE: ${{ matrix.build_type }}

61
.github/workflows/build_release.yaml vendored Normal file
View File

@ -0,0 +1,61 @@
on:
workflow_dispatch:
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: write
strategy:
matrix:
debian_version: [bullseye]
docker_arch: [amd64, arm32v7, arm64v8]
build_type: [generic, raspi]
exclude:
- docker_arch: amd64
build_type: raspi
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
submodules: recursive
- name: Set GIT_VERSION
shell: bash
run: |
majorVer=$(cat VERSION)
lastVer=$(git tag --sort version:refname --list "v$majorVer.*" | tail -n1)
if [[ -n "$lastVer" ]]; then
newVer=(${lastVer//./ })
newVer[-1]="$((${newVer[-1]}+1))"
nextVer="${newVer[*]}"
nextVer="${nextVer// /.}"
else
nextVer="$majorVer.0"
fi
echo "MajorVer=$majorVer LastVer=$lastVer NextVer=$nextVer"
echo "GIT_VERSION=$nextVer" >> $GITHUB_ENV
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Build Dockerfile
run: docker build --target deb_make --tag deb_make --file .github/ci/Dockerfile --build-arg GIT_VERSION --build-arg DOCKER_ARCH --build-arg DEBIAN_VERSION --build-arg BUILD_TYPE .
env:
DEBIAN_VERSION: ${{ matrix.debian_version }}
DOCKER_ARCH: ${{ matrix.docker_arch }}/
BUILD_TYPE: ${{ matrix.build_type }}
- name: Create container
run: docker create --name deb_make deb_make
- name: Copy files
run: 'docker cp deb_make:/deb/. deb/'
- name: 'Release debian files'
uses: ncipollo/release-action@v1
with:
tag: ${{ env.GIT_VERSION }}
artifacts: "deb/*.deb"
allowUpdates: true
omitBodyDuringUpdate: true
omitNameDuringUpdate: true
updateOnlyUnreleased: true
prerelease: true
generateReleaseNotes: true
bodyFile: RELEASE.md

44
.github/workflows/build_test.yaml vendored Normal file
View File

@ -0,0 +1,44 @@
on:
push:
paths-ignore:
- '.github/workflows/build_test.yaml'
- 'RELEASE.md'
pull_request:
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
debian_version: [buster, bullseye]
docker_arch: [amd64, arm32v7, arm64v8]
build_type: [generic, raspi]
exclude:
- docker_arch: amd64
build_type: raspi
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
submodules: recursive
- name: Set GIT_VERSION
run: echo "GIT_VERSION=$(git describe --tags)" >> $GITHUB_ENV
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Build Dockerfile
run: docker build --target deb_make --tag deb_make --file .github/ci/Dockerfile --build-arg GIT_VERSION --build-arg DOCKER_ARCH --build-arg DEBIAN_VERSION --build-arg BUILD_TYPE .
env:
DEBIAN_VERSION: ${{ matrix.debian_version }}
DOCKER_ARCH: ${{ matrix.docker_arch }}/
BUILD_TYPE: ${{ matrix.build_type }}
- name: Create container
run: docker create --name deb_make deb_make
- name: Copy files
run: docker cp deb_make:/deb/. deb/
- name: 'Upload debian files'
uses: actions/upload-artifact@v3
with:
name: ${{ matrix.debian_version }}-${{ matrix.docker_arch }}-${{ matrix.build_type }}.zip
path: deb/
retention-days: 14