From f9f42192324d56f9028822d2b98d395002c9c23b Mon Sep 17 00:00:00 2001 From: Antoine van Gelder Date: Tue, 30 Jul 2024 17:23:26 +0200 Subject: [PATCH] Actually add the test workflow this time --- .github/workflows/test.yml | 172 ++++++++++++++++++++++++++++++++ appimage/test/action.yml | 30 ++++++ appimage/test/docker/Dockerfile | 33 ++++++ 3 files changed, 235 insertions(+) create mode 100644 .github/workflows/test.yml create mode 100644 appimage/test/action.yml create mode 100644 appimage/test/docker/Dockerfile diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 00000000..f0e023d4 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,172 @@ +on: + push: + pull_request: + workflow_dispatch: + +name: CI-TEST + +env: + IMAGE_NAME: ${{ github.repository }}-test + IMAGE_TAG: ${{ github.ref_name }} + +defaults: + run: + shell: bash + working-directory: /home/runner + +jobs: + create-test-docker-image: + permissions: + contents: read + packages: write + attestations: write + id-token: write + + name: Create Test Docker image + runs-on: ubuntu-latest + outputs: + NAME: ${{ env.IMAGE_NAME }} + TAG: ${{ env.IMAGE_TAG }} + + steps: + - name: Checkout repository + uses: actions/checkout@v4 + + - name: Escape Docker image tag + run: | + echo "IMAGE_TAG=$(echo ${{ env.IMAGE_TAG }} | sed -e 's/\//-/g')" >> $GITHUB_ENV + echo "IMAGE_NAME: ${{ env.IMAGE_NAME }}" + echo "IMAGE_TAG: ${{ env.IMAGE_TAG }}" + + - name: Use 'main' Docker image tag if this is a PR from a fork + id: origin + shell: bash + if: github.event.pull_request.head.repo.fork + run: | + echo gh.pr: ${{ github.event.pull_request.repo.full_name }} + echo gh.fork: ${{ github.event.pull_request.head.repo.fork }} + echo gh.repo: ${{ github.repository }} + echo 'IMAGE_TAG=main' >> $GITHUB_ENV + + - name: Check if Dockerfile has changed + uses: dorny/paths-filter@v3 + id: changed + with: + base: ${{ github.ref_name }} + filters: | + dockerfile: + - "appimage/test/docker/**" + + - name: Check if Docker image exists + id: exists + shell: bash + run: | + declare -a HEADERS=( + '-H' "Accept: application/vnd.oci.image.manifest.v1+json" + '-H' "Accept: application/vnd.oci.image.index.v1+json" + '-H' "Authorization: Bearer $(echo ${{ secrets.GITHUB_TOKEN }} | base64)" + ) + RESULT=$(curl "${HEADERS[@]}" https://ghcr.io/v2/${IMAGE_NAME}/manifests/${IMAGE_TAG}) + echo 'dockerimage<> $GITHUB_OUTPUT + echo ${RESULT} | jq 'has("manifests")' >> $GITHUB_OUTPUT + echo 'EOF' >> $GITHUB_OUTPUT + echo + echo exists: ${{ steps.exists.outputs.dockerimage }} + + - name: Check if we need to build the Docker image + id: dockerimage + if: | + ! github.event.pull_request.head.repo.fork && + (steps.changed.outputs.dockerfile == 'true' || steps.exists.outputs.dockerimage == 'false') + run: | + echo 'build=true' >> $GITHUB_OUTPUT + + - name: Debug Check + shell: bash + run: | + echo IMAGE_NAME: ${{ env.IMAGE_NAME }} # /-test + echo IMAGE_TAG: ${{ env.IMAGE_TAG }} # + echo + echo gh.actor: ${{ github.actor }} # antoinevg antoinevg + echo gh.trig_actor: ${{ github.triggering_actor }} # antoinevg antoinevg + echo gh.repo: ${{ github.repository }} # antoinevg/packetry greatscottgadgets/packetry + echo gh.repo_owner: ${{ github.repository_owner }} # antoinevg greatscottgadgets + echo gh.base_ref: ${{ github.base_ref }} # main + echo gh.head_ref: ${{ github.head_ref }} # antoinevg/fix-pr-403 + echo gh.ref_name: ${{ github.ref_name }} # antoinevg/fix-pr-403 149/merge + echo + echo check.forked: ${{ github.event.pull_request.head.repo.fork }} # true + echo check.changed: ${{ steps.changed.outputs.dockerfile }} # true true + echo check.exists: ${{ steps.exists.outputs.dockerimage }} # false false + echo + echo build: ${{ steps.dockerimage.outputs.build }} + + - name: Log in to the Container registry + if: steps.dockerimage.outputs.build + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Set up Docker Buildx + if: steps.dockerimage.outputs.build + uses: docker/setup-buildx-action@v3 + + - name: Build and push Docker image + if: steps.dockerimage.outputs.build + id: push + uses: docker/build-push-action@v6 + with: + context: appimage/test/docker/ + push: true + tags: ghcr.io/${{ env.IMAGE_NAME }}:${{ env.IMAGE_TAG }} + cache-from: type=gha, scope=${{ env.IMAGE_TAG }} + cache-to: type=gha, scope=${{ env.IMAGE_TAG }}, mode=max + + - name: Generate artifact attestation + if: steps.dockerimage.outputs.build + uses: actions/attest-build-provenance@v1 + with: + subject-name: ghcr.io/${{ env.IMAGE_NAME }} + subject-digest: ${{ steps.push.outputs.digest }} + push-to-registry: true + + + test-remote: + permissions: + contents: read + packages: read + + needs: create-test-docker-image + + name: Run test action + runs-on: ubuntu-latest + + container: + image: ghcr.io/${{ needs.create-test-docker-image.outputs.NAME }}:${{ needs.create-test-docker-image.outputs.TAG }} + options: --user root # see: https://github.com/actions/checkout/issues/1014 + credentials: + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + steps: + - name: Check image name & tag + run: | + echo "NAME: ${{ needs.create-test-docker-image.outputs.NAME }}" + echo "TAG: ${{ needs.create-test-docker-image.outputs.TAG }}" + + - name: Checkout repository + uses: actions/checkout@v4 + + - name: Check environment + run: | + echo PATH: $PATH + echo HOME: $HOME + echo pwd: `pwd` + ls -al + + - name: Test Action + uses: ./appimage/test/ + with: + executable: ./target/release/packetry diff --git a/appimage/test/action.yml b/appimage/test/action.yml new file mode 100644 index 00000000..3cbf37be --- /dev/null +++ b/appimage/test/action.yml @@ -0,0 +1,30 @@ +name: "Test Action" +description: "Tests a composite action" +inputs: + executable: + description: "Executable file" + required: true + icon-file: + description: "Icon file to use for Executable" + required: true + desktop-file: + description: "Desktop file to use for Executable" + required: true + +runs: + # the problem with this is that it does not actually run any steps, it just runs the docker image :-/ + #using: "docker" + #image: ./docker/Dockerfile + + using: "composite" + + steps: + - name: Print the name + run: | + echo "Print the name of the executable: ${{ inputs.executable }}" + shell: bash + + - name: Print docker env var + run: | + echo "Print the path for gtk4: $GTK4" + shell: bash diff --git a/appimage/test/docker/Dockerfile b/appimage/test/docker/Dockerfile new file mode 100644 index 00000000..9a3e0543 --- /dev/null +++ b/appimage/test/docker/Dockerfile @@ -0,0 +1,33 @@ +FROM debian:10 AS builder +LABEL maintainer="Great Scott Gadgets " +LABEL stage="builder" +LABEL org.opencontainers.image.source=https://github.com/greatscottgadgets/packetry +LABEL org.opencontainers.image.description="GSG Test Image" +LABEL org.opencontainers.image.licenses=BSD-3-Clause + +# - setup base system --------------------------------------------------------- + +USER root + +# add user +RUN useradd -ms /bin/bash runner + +# - squish -------------------------------------------------------------------- + +# FROM debian:10 +# COPY --from=builder / / + +# See: https://github.com/actions/checkout/issues/1014 +#ENV RUNNER="runner" +#ENV HOME="/home/$RUNNER" +ENV RUNNER="root" +ENV HOME="/github/home" + +# gtk-4.0 +ENV GTK_VERSION="4.14.4" +ENV GTK4="/opt/gtk-$GTK_VERSION" + +# bump: 2 + +USER $RUNNER +WORKDIR $HOME \ No newline at end of file