Build and Push PDP Docker Image #99
Workflow file for this run
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
name: Build and Push PDP Docker Image | |
on: | |
release: | |
types: [published] | |
jobs: | |
pdp-tests: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- uses: actions/checkout@v3 | |
with: | |
repository: permitio/permit-opa | |
ref: main | |
path: './permit-opa' | |
token: ${{ secrets.CLONE_REPO_TOKEN }} | |
- name: Pre build PDP tests | |
run: | | |
rm -rf custom | |
mkdir custom | |
build_root="$PWD" | |
cd ./permit-opa | |
find * -name '*go*' -print0 | xargs -0 tar -czf "$build_root"/custom/custom_opa.tar.gz --exclude '.*' | |
- name: Build and load image for PDP E2E tests | |
uses: docker/build-push-action@v5 | |
with: | |
push: false | |
load: true | |
context: . | |
platforms: linux/amd64 | |
tags: permitio/pdp-v2:test | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
- uses: actions/checkout@v3 | |
with: | |
repository: permitio/permit-backend | |
ref: main | |
path: './permit-backend' | |
token: ${{ secrets.CLONE_REPO_TOKEN }} | |
- name: Python setup | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.11.8' | |
- name: Run Pytests | |
run: | | |
export PYTHONPATH=$(pwd) | |
python -m pip install --upgrade pip | |
python setup.py install | |
if [ -f requirements-dev.txt ]; then pip install -r requirements-dev.txt; fi | |
if [ -f requirements.txt ]; then pip install -r requirements.txt; fi | |
pytest -s --cache-clear horizon/tests/ | |
- name: Run E2E tests | |
working-directory: ./permit-backend/proactive_tests/sidecar | |
run: | | |
pip install requests pydantic==1.8.2 docker | |
python sidecar_tester.py -k ${{ secrets.PERMIT_TESTS_TOKEN }} -u https://api.permit.io -2 permitio/pdp-v2:test --no-pull | |
build-and-push-pdp-vanilla: | |
needs: pdp-tests | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Pre build - for PDP-Vanilla | |
run: echo "${{ github.event.release.tag_name }}" | cut -d '-' -f 1 > permit_pdp_version | |
- name: Build and push PDP-Vanilla - (official release) | |
if: "!github.event.release.prerelease" | |
uses: docker/build-push-action@v5 | |
with: | |
push: true | |
context: . | |
platforms: linux/amd64,linux/arm64 | |
tags: permitio/pdp-v2-vanilla:${{ github.event.release.tag_name }}, permitio/pdp-v2-vanilla:latest | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
- name: Build and push PDP-Vanilla image - (pre-release) | |
if: "github.event.release.prerelease" | |
uses: docker/build-push-action@v5 | |
with: | |
push: true | |
context: . | |
platforms: linux/amd64,linux/arm64 | |
tags: permitio/pdp-v2-vanilla:${{ github.event.release.tag_name }} | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
build-and-push-pdp: | |
needs: pdp-tests | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- uses: actions/checkout@v3 | |
with: | |
repository: permitio/permit-opa | |
ref: main | |
path: './permit-opa' | |
token: ${{ secrets.CLONE_REPO_TOKEN }} | |
- name: Pre build PDP | |
run: | | |
echo "${{ github.event.release.tag_name }}" | cut -d '-' -f 1 > permit_pdp_version | |
rm -rf custom | |
mkdir custom | |
build_root="$PWD" | |
cd ./permit-opa | |
find * -name '*go*' -print0 | xargs -0 tar -czf "$build_root"/custom/custom_opa.tar.gz --exclude '.*' | |
- name: Build and push PDP image - (pre-release) | |
if: "github.event.release.prerelease" | |
uses: docker/build-push-action@v5 | |
with: | |
push: true | |
context: . | |
platforms: linux/amd64,linux/arm64 | |
tags: permitio/pdp-v2:${{ github.event.release.tag_name }} | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
- name: Build and push PDP image - (official release) | |
if: "!github.event.release.prerelease" | |
uses: docker/build-push-action@v5 | |
with: | |
push: true | |
context: . | |
platforms: linux/amd64,linux/arm64 | |
tags: permitio/pdp-v2:${{ github.event.release.tag_name }},permitio/pdp-v2:latest | |
cache-from: type=gha | |
cache-to: type=gha,mode=max |