Skip to content

Commit

Permalink
Package for bookworm (#321)
Browse files Browse the repository at this point in the history
  • Loading branch information
jcapona authored Feb 22, 2024
1 parent a6e7add commit aa16226
Show file tree
Hide file tree
Showing 6 changed files with 58 additions and 36 deletions.
31 changes: 18 additions & 13 deletions .github/workflows/deb-build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,14 @@ on:

env:
DEB_BUILD_DOCKER_IMAGE: "pitop/pi-top-os-deb-build"
DEB_BUILD_DOCKER_TAG: "latest"
DEB_BUILD_DOCKER_BRANCH: "master"
CHANGELOG_AUTHOR_NAME: "pi-top"
CHANGELOG_AUTHOR_EMAIL: "deb-maintainers@pi-top.com"
PACKAGECLOUD_REPO: "experimental"
OS: "debian"
DISTRO: "bullseye"
HOST_COMPILE: "{\"architecture\":[\"amd64\"]}"
X_COMPILE: "{\"architecture\":[\"armhf\", \"arm64\"]}" # ARM 32 and 64 bit
DISTROS: "\"distro\":[\"bookworm\", \"bullseye\"]"
HOST_COMPILE: "\"architecture\":[\"amd64\"]"
X_COMPILE: "\"architecture\":[\"armhf\", \"arm64\"]" # ARM 32 and 64 bit

jobs:
check-architecture:
Expand All @@ -34,11 +34,11 @@ jobs:
# If any packages define architecture as other than 'all'
# then it can't be compiled on host architecture
run: |
architecture=$HOST_COMPILE
if grep '^Architecture:' debian/control | grep -q -v 'all'; then
echo "matrix=$X_COMPILE" >>$GITHUB_OUTPUT
else
echo "matrix=$HOST_COMPILE" >>$GITHUB_OUTPUT
architecture=$X_COMPILE
fi
echo "matrix={$architecture, $DISTROS}">>$GITHUB_OUTPUT
build-debian-package:
needs: check-architecture
Expand All @@ -64,37 +64,42 @@ jobs:
snapshot_number: ${{ steps.version.outputs.distance }}
since: ${{ steps.version.outputs.tag_latest }}

- name: Patch lintian-overrides
if: matrix.distro == 'bullseye'
run:
cp -r debian/bullseye-overrides/* debian/ || true

- name: Build Debian package
uses: pi-top/debian-package-build-action@master
with:
# https://github.com/pi-top/debian-package-build-action/pull/19
# lintian_check_changelog_spelling: false
target_architecture: ${{ matrix.architecture }}
docker_image: ${{ env.DEB_BUILD_DOCKER_IMAGE }}:${{ env.DEB_BUILD_DOCKER_TAG }}
docker_image: ${{ env.DEB_BUILD_DOCKER_IMAGE }}:${{ matrix.distro }}-${{ env.DEB_BUILD_DOCKER_BRANCH }}
signing_key: ${{ secrets.DEB_SIGNING_GPG_KEY }}
signing_passphrase: ${{ secrets.DEB_SIGNING_GPG_PASSPHRASE }}
build_directory: ./artifacts
LINTIAN_SHOW_OVERRIDES: 0
# Optional, repo-specific build environment variables
additional_env: |
DATA="${{ secrets.DATA }}"
TLS_KEY="${{ secrets.CERT_PRIVATE_KEY }}"
PYTHON_PACKAGE_VERSION="${{ steps.version.outputs.tag_latest_ltrimv }}"
- name: Generate artifact name
run: |
echo "ARTIFACT_PREFIX=$(basename -s .dsc "$(find . -name "*.dsc")")" >> $GITHUB_ENV
- name: Upload binary package artifacts
uses: actions/upload-artifact@v3
with:
name: ${{ env.ARTIFACT_PREFIX }}.deb
name: ${{ matrix.distro }}-${{ env.ARTIFACT_PREFIX }}.deb
path: ./artifacts/*.deb

- name: Upload source package artifacts
uses: actions/upload-artifact@v3
with:
name: ${{ env.ARTIFACT_PREFIX }}.deb-src
name: ${{ matrix.distro }}-${{ env.ARTIFACT_PREFIX }}.deb-src
path: ./artifacts/*.tar.xz

- name: Upload package build metadata artifacts
Expand All @@ -118,7 +123,7 @@ jobs:
)
)
with:
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ env.DISTRO }}
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ matrix.distro }}
files: |
./artifacts/*.dsc
env:
Expand All @@ -128,7 +133,7 @@ jobs:
uses: pi-top/ghaction-packagecloud@main
if: github.ref == 'refs/heads/master'
with:
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ env.DISTRO }}
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ matrix.distro }}
files: |
./artifacts/*.deb
env:
Expand Down
49 changes: 31 additions & 18 deletions .github/workflows/deb-release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,12 @@ on:

env:
DEB_BUILD_DOCKER_IMAGE: "pitop/pi-top-os-deb-build"
DEB_BUILD_DOCKER_TAG: "latest"
DEB_BUILD_DOCKER_BRANCH: "master"
PACKAGECLOUD_REPO: "pi-top-os-unstable"
OS: "debian"
DISTRO: "bullseye"
HOST_COMPILE: "{\"architecture\":[\"amd64\"]}"
X_COMPILE: "{\"architecture\":[\"armhf\", \"arm64\"]}" # ARM 32 and 64 bit
DISTROS: "\"distro\":[\"bookworm\", \"bullseye\"]"
HOST_COMPILE: "\"architecture\":[\"amd64\"]"
X_COMPILE: "\"architecture\":[\"armhf\", \"arm64\"]" # ARM 32 and 64 bit

jobs:
check-architecture:
Expand All @@ -35,11 +35,11 @@ jobs:
# If any packages define architecture as other than 'all'
# then it can't be compiled on host architecture
run: |
architecture=$HOST_COMPILE
if grep '^Architecture:' debian/control | grep -q -v 'all'; then
echo "matrix=$X_COMPILE" >>$GITHUB_OUTPUT
else
echo "matrix=$HOST_COMPILE" >>$GITHUB_OUTPUT
architecture=$X_COMPILE
fi
echo "matrix={$architecture, $DISTROS}">>$GITHUB_OUTPUT
release:
needs: check-architecture
Expand Down Expand Up @@ -72,14 +72,22 @@ jobs:
if: ${{ env.LATEST_TAG != '' }}
run: dpkg --compare-versions ${{ env.CURRENT_VERSION }} gt ${{ env.LATEST_TAG }}

- name: Patch lintian-overrides
if: matrix.distro == 'bullseye'
run:
cp -r debian/bullseye-overrides/* debian/ || true

- name: Build Debian package
uses: pi-top/debian-package-build-action@master
with:
# https://github.com/pi-top/debian-package-build-action/pull/19
# lintian_check_changelog_spelling: false
target_architecture: ${{ matrix.architecture }}
docker_image: ${{ env.DEB_BUILD_DOCKER_IMAGE }}:${{ env.DEB_BUILD_DOCKER_TAG }}
docker_image: ${{ env.DEB_BUILD_DOCKER_IMAGE }}:${{ matrix.distro }}-${{ env.DEB_BUILD_DOCKER_BRANCH }}
signing_key: ${{ secrets.DEB_SIGNING_GPG_KEY }}
signing_passphrase: ${{ secrets.DEB_SIGNING_GPG_PASSPHRASE }}
build_directory: ./artifacts
LINTIAN_SHOW_OVERRIDES: 0
# Optional, repo-specific build environment variables
additional_env: |
DATA="${{ secrets.DATA }}"
Expand All @@ -105,7 +113,7 @@ jobs:
)
with:
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ env.DISTRO }}
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ matrix.distro }}
files: |
./artifacts/*.dsc
env:
Expand All @@ -114,18 +122,23 @@ jobs:
- name: Upload .deb to PackageCloud
uses: pi-top/ghaction-packagecloud@main
with:
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ env.DISTRO }}
repository: ${{ env.PACKAGECLOUD_REPO }}/${{ env.OS }}/${{ matrix.distro }}
files: |
./artifacts/*.deb
env:
PACKAGECLOUD_TOKEN: ${{ secrets.PACKAGECLOUD_TOKEN }}

- name: Create Release
uses: softprops/action-gh-release@v1
- name: Install zip
uses: montudor/action-zip@v1

- name: Zip distro artifacts
run: |
ls -l ./artifacts
zip ${{ matrix.distro }}.deb.zip ./artifacts/*.deb
- name: Create release and upload package
uses: svenstaro/upload-release-action@v2
with:
tag_name: "v${{ env.CURRENT_VERSION }}"
name: "v${{ env.CURRENT_VERSION }}"
draft: false
prerelease: false
files: ./artifacts/*
token: ${{ secrets.PAT_GITHUB }}
repo_token: ${{ secrets.PAT_GITHUB }}
file: ./${{ matrix.distro}}.deb.zip
tag: "v${{ env.CURRENT_VERSION }}"
3 changes: 3 additions & 0 deletions debian/bullseye-overrides/pt-miniscreen.lintian-overrides
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
pt-miniscreen: no-manual-page usr/bin/pt-miniscreen
pt-miniscreen: no-manual-page usr/bin/pt-miniscreen-should-start
pt-miniscreen: package-supports-alternative-init-but-no-init.d-script lib/systemd/system/pt-miniscreen.service
6 changes: 3 additions & 3 deletions debian/pt-miniscreen.lintian-overrides
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
pt-miniscreen: no-manual-page usr/bin/pt-miniscreen
pt-miniscreen: no-manual-page usr/bin/pt-miniscreen-should-start
pt-miniscreen: package-supports-alternative-init-but-no-init.d-script lib/systemd/system/pt-miniscreen.service
pt-miniscreen: no-manual-page [usr/bin/pt-miniscreen]
pt-miniscreen: no-manual-page [usr/bin/pt-miniscreen-should-start]
pt-miniscreen: package-supports-alternative-init-but-no-init.d-script [lib/systemd/system/pt-miniscreen.service]
2 changes: 1 addition & 1 deletion debian/py3dist-overrides
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
click python3-click; PEP386
matplotlib python3-matplotlib; PEP386
monotonic python3-monotonic; PEP386
numpy python3-numpy(>=1:1.19.5), python3-numpy(<<1:1.20)
numpy python3-numpy; PEP386
Pillow python3-pil; PEP386
psutil python3-psutil; PEP386
pyzmq python3-zmq; PEP386
Expand Down
3 changes: 2 additions & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,8 @@ install_requires =
numpy >= 1.19.5
Pillow >= 8.1.2
psutil >= 5.8.0
pyzmq >= 20.0.0
pyzmq>=20.0.0,<21.0.0;python_version=='3.9'
pyzmq>=24.0.0,<30.0.0;python_version=='3.11'

[options.package_data]
* = *.gif, *.png
Expand Down

0 comments on commit aa16226

Please sign in to comment.