Let plugins decide if events should be processed or not (#5618) #36
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Build, test and push InvenTree docker image | |
# This workflow runs under any of the following conditions: | |
# | |
# - Push to the master branch | |
# - Publish release | |
# | |
# The following actions are performed: | |
# | |
# - Check that the version number matches the current branch or tag | |
# - Build the InvenTree docker image | |
# - Run suite of unit tests against the build image | |
# - Push the compiled, tested image to dockerhub | |
name: Docker | |
on: | |
release: | |
types: [ published ] | |
push: | |
branches: | |
- 'master' | |
# pull_request: | |
# branches: | |
# - 'master' | |
jobs: | |
# Build the docker image | |
build: | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
id-token: write | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
python_version: 3.9 | |
steps: | |
- name: Check out repo | |
uses: actions/checkout@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # pin@v3.1.0 | |
- name: Set Up Python ${{ env.python_version }} | |
uses: actions/setup-python@13ae5bb136fac2878aff31522b9efb785519f984 # pin@v4.3.0 | |
with: | |
python-version: ${{ env.python_version }} | |
- name: Version Check | |
run: | | |
pip install requests | |
pip install pyyaml | |
python3 ci/version_check.py | |
echo "git_commit_hash=$(git rev-parse --short HEAD)" >> $GITHUB_ENV | |
echo "git_commit_date=$(git show -s --format=%ci)" >> $GITHUB_ENV | |
- name: Build Docker Image | |
# Build the development docker image (using docker-compose.yml) | |
run: | | |
docker-compose build --no-cache | |
- name: Update Docker Image | |
run: | | |
docker-compose run inventree-dev-server invoke update | |
docker-compose run inventree-dev-server invoke setup-dev | |
docker-compose up -d | |
docker-compose run inventree-dev-server pip install setuptools==68.1.2 | |
docker-compose run inventree-dev-server invoke wait | |
- name: Check Data Directory | |
# The following file structure should have been created by the docker image | |
run: | | |
test -d data | |
test -d data/env | |
test -d data/pgdb | |
test -d data/media | |
test -d data/static | |
test -d data/plugins | |
test -f data/config.yaml | |
test -f data/plugins.txt | |
test -f data/secret_key.txt | |
- name: Run Unit Tests | |
run: | | |
echo "GITHUB_TOKEN=${{ secrets.GITHUB_TOKEN }}" >> docker.dev.env | |
docker-compose run inventree-dev-server invoke test --disable-pty | |
docker-compose run inventree-dev-server invoke test --migrations --disable-pty | |
docker-compose down | |
- name: Set up QEMU | |
if: github.event_name != 'pull_request' | |
uses: docker/setup-qemu-action@e81a89b1732b9c48d79cd809d8d81d79c4647a18 # pin@v2.1.0 | |
- name: Set up Docker Buildx | |
if: github.event_name != 'pull_request' | |
uses: docker/setup-buildx-action@95cb08cb2672c73d4ffd2f422e6d11953d2a9c70 # pin@v2.1.0 | |
- name: Set up cosign | |
if: github.event_name != 'pull_request' | |
uses: sigstore/cosign-installer@7cc35d7fdbe70d4278a0c96779081e6fac665f88 # pin@v2.8.0 | |
- name: Login to Dockerhub | |
if: github.event_name != 'pull_request' | |
uses: docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a # pin@v2.1.0 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Log into registry ghcr.io | |
if: github.event_name != 'pull_request' | |
uses: docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a # pin@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract Docker metadata | |
if: github.event_name != 'pull_request' | |
id: meta | |
uses: docker/metadata-action@12cce9efe0d49980455aaaca9b071c0befcdd702 # pin@v4.1.0 | |
with: | |
images: | | |
inventree/inventree | |
ghcr.io/inventree/inventree | |
- name: Build and Push | |
id: build-and-push | |
if: github.event_name != 'pull_request' | |
uses: docker/build-push-action@c56af957549030174b10d6867f20e78cfd7debc5 # pin@v3.2.0 | |
with: | |
context: . | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
sbom: true | |
provenance: false | |
target: production | |
tags: ${{ env.docker_tags }} | |
build-args: | | |
commit_hash=${{ env.git_commit_hash }} | |
commit_date=${{ env.git_commit_date }} | |
- name: Sign the published image | |
if: ${{ false }} # github.event_name != 'pull_request' | |
env: | |
COSIGN_EXPERIMENTAL: "true" | |
run: cosign sign ${{ steps.meta.outputs.tags }}@${{ | |
steps.build-and-push.outputs.digest }} |