Skip to content

Merge pull request #712 from gefyrahq/feature/703_better-registry-han… #2218

Merge pull request #712 from gefyrahq/feature/703_better-registry-han…

Merge pull request #712 from gefyrahq/feature/703_better-registry-han… #2218

name: pytest and try it yourself example
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
jobs:
build_test_image:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
# https://github.com/docker/setup-qemu-action
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
# https://github.com/docker/setup-buildx-action
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v3
- name: PyServer Test Image meta
id: test_image_meta
uses: docker/metadata-action@v5
with:
flavor: |
latest=false
images: |
gefyra/pyserver
tags: |
type=ref,event=pr,enable=${{ !!github.event.pull_request }}
type=raw,value=test-run-${{ github.run_id }},enable=${{ !github.event.pull_request }}
labels: |
quay.expires-after=24h
- name: Build and push
uses: docker/build-push-action@v6
env:
DOCKER_BUILD_NO_SUMMARY: true
with:
context: testing/images/
platforms: linux/amd64
push: false
load: true
file: testing/images/Dockerfile.local
tags: pyserver
outputs: type=docker,dest=/tmp/pyserver.tar
- name: Upload pyserver image
uses: actions/upload-artifact@v4
with:
name: pyserver
path: /tmp/pyserver.tar
build_operator:
runs-on: ubuntu-latest
outputs:
tags: ${{ steps.operator_meta.outputs.tags }}
steps:
- name: Checkout
uses: actions/checkout@v4
# https://github.com/docker/setup-qemu-action
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
# https://github.com/docker/setup-buildx-action
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v3
- name: Login to quay.io
uses: docker/login-action@v3
with:
registry: quay.io
username: ${{ secrets.QUAY_ROBOT }}
password: ${{ secrets.QUAY_ROBOT_TOKEN }}
#
# Gefyra Operator
#
- name: Operator Image meta
id: operator_meta
uses: docker/metadata-action@v5
with:
flavor: |
latest=false
images: |
quay.io/gefyra/operator
tags: |
type=raw,value=test-run-${{ github.run_id }},enable=${{ !github.event.pull_request }}
type=ref,event=pr,enable=${{ !!github.event.pull_request }}
labels: |
quay.expires-after=24h
- name: Build and push
uses: docker/build-push-action@v6
env:
DOCKER_BUILD_NO_SUMMARY: true
with:
context: operator/
platforms: linux/amd64
push: true
load: false
tags: ${{ steps.operator_meta.outputs.tags }}
labels: ${{ steps.operator_meta.outputs.labels }}
cache-from: type=registry,ref=quay.io/gefyra/operator:latest
outputs: type=docker,dest=/tmp/operator.tar
- name: Upload operator image
uses: actions/upload-artifact@v4
with:
name: operator
path: /tmp/operator.tar
build_cargo:
runs-on: ubuntu-latest
outputs:
tags: ${{ steps.cargo_meta.outputs.tags }}
steps:
- name: Checkout
uses: actions/checkout@v4
# https://github.com/docker/setup-qemu-action
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
# https://github.com/docker/setup-buildx-action
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v3
#
# Gefyra Cargo
#
- name: Cargo Image meta
id: cargo_meta
uses: docker/metadata-action@v5
with:
flavor: |
latest=false
images: |
quay.io/gefyra/cargo
tags: |
type=raw,value=test-run-${{ github.run_id }},enable=${{ !github.event.pull_request }}
type=ref,event=pr,enable=${{ !!github.event.pull_request }}
labels: |
quay.expires-after=24h
- name: Build and push
uses: docker/build-push-action@v6
env:
DOCKER_BUILD_NO_SUMMARY: true
with:
context: cargo/
platforms: linux/amd64
push: false
target: cargo
tags: ${{ steps.cargo_meta.outputs.tags }}
labels: ${{ steps.cargo_meta.outputs.labels }}
cache-from: type=registry,ref=quay.io/gefyra/cargo:latest
outputs: type=docker,dest=/tmp/cargo.tar
- name: Upload cargo image
uses: actions/upload-artifact@v4
with:
name: cargo
path: /tmp/cargo.tar
test_python:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set fake kubeconfig
shell: bash
run: |
mkdir -p ~/.kube/
cd ~/.kube
touch config
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.9'
- name: Set Gefyra tracking config / fake kubeconfig
shell: bash
run: |
mkdir -p ~/.gefyra
cd ~/.gefyra
touch config.ini
echo "[telemetry]" >> config.ini
echo "track = False" >> config.ini
- name: Install Poetry
uses: snok/install-poetry@v1
with:
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true
- name: Install dependencies
working-directory: ./client
run: poetry install --with dev --no-interaction --no-root
- name: Install k3d
run: curl --silent --fail https://raw.githubusercontent.com/k3d-io/k3d/main/install.sh | TAG=v5.5.1 bash
- name: Run PyTest
working-directory: ./client
run: poetry run coverage run -m pytest tests/unit/
- name: Upload coverage data to coveralls.io
if: github.repository == 'gefyrahq/gefyra'
working-directory: ./client
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}
COVERALLS_FLAG_NAME: client
COVERALLS_PARALLEL: true
run: poetry run coveralls --service=github-actions
- uses: actions/upload-artifact@v4
with:
name: coverage_data
path: ./client/.coverage*
test_minikube:
timeout-minutes: 90
strategy:
fail-fast: false
matrix:
include:
- os: ubuntu-latest
driver: ''
kubectl_os: linux
- os: macos-13
driver: virtualbox
kubectl_os: darwin
needs:
- build_operator
- build_cargo
- build_test_image
runs-on: ${{ matrix.os }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.9'
# https://github.com/opensafely-core/job-server/issues/3429
- run: brew install docker
if: ${{ matrix.os == 'macos-13' }}
- name: Install QEMU 9.0.2
uses: docker/actions-toolkit/.github/actions/macos-setup-qemu@ea5e6b5583a8fd470ffecc0b3f4670e5ce4f8ed2
if: ${{ matrix.os == 'macos-13' }}
- name: Set up Docker
uses: crazy-max/ghaction-setup-docker@v4
if: ${{ matrix.os == 'macos-13' }}
- name: Install Poetry
uses: snok/install-poetry@v1
with:
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true
- name: Set Gefyra tracking config / fake kubeconfig
shell: bash
run: |
mkdir -p ~/.gefyra
mkdir -p ~/.kube
cd ~/.gefyra
touch config.ini
echo "[telemetry]" >> config.ini
echo "track = False" >> config.ini
cd ~/.kube
touch config
- name: Download artifact
uses: actions/download-artifact@v4
with:
path: /tmp
- name: start minikube
id: minikube
uses: medyagh/setup-minikube@latest
with:
start-args: --ports 127.0.0.1:31820:31820/udp
- name: Load Gefyra images
run: |
eval $(minikube docker-env)
docker load --input /tmp/pyserver/pyserver.tar
docker load --input /tmp/cargo/cargo.tar
docker load --input /tmp/operator/operator.tar
docker tag ${{ needs.build_operator.outputs.tags }} quay.io/gefyra/operator:2.1.6
docker image ls -a
- name: Install dependencies
working-directory: ./client
run: poetry install --with dev --no-interaction --no-root
- name: Run gefyra up
timeout-minutes: 8
working-directory: ./client
run: |
poetry run coverage run -a -m gefyra.cli.main --debug up --minikube
- name: Show cargo logs
working-directory: ./client
if: ${{ failure() }}
run: |
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/${{ matrix.kubectl_os }}/amd64/kubectl"
chmod +x ./kubectl
./kubectl get pod -n gefyra
./kubectl logs -n gefyra gefyra-stowaway-0
./kubectl logs --previous -n gefyra deploy/gefyra-operator-webhook
./kubectl logs -n gefyra deploy/gefyra-operator-webhook
./kubectl describe pods -n gefyra -l gefyra.dev/role=webhook
./kubectl logs -n gefyra deploy/gefyra-operator
docker inspect minikube
docker inspect gefyra-cargo-default
docker logs gefyra-cargo-default
- name: Show coverage report
working-directory: ./client
run: |
poetry run coverage report
- name: Upload coverage data to coveralls.io
if: github.repository == 'gefyrahq/gefyra'
working-directory: ./client
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}
COVERALLS_FLAG_NAME: client
COVERALLS_PARALLEL: true
run: |
poetry run coveralls --service=github-actions
- uses: actions/upload-artifact@v4
with:
name: coverage_data-${{ matrix.os }}
path: ./client/.coverage*
test:
strategy:
fail-fast: false
matrix:
k3d: [v1.25.16-k3s4, v1.26.15-k3s1, v1.27.14-k3s1, v1.28.10-k3s1, v1.29.5-k3s1, v1.30.1-k3s1]
needs:
- build_cargo
- build_operator
- build_test_image
runs-on: ubuntu-latest
timeout-minutes: 45
steps:
- name: Checkout
uses: actions/checkout@v4
# https://github.com/docker/setup-qemu-action
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.9'
- name: Install Poetry
uses: snok/install-poetry@v1
with:
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true
- name: Set Gefyra tracking config / fake kubeconfig
shell: bash
run: |
mkdir -p ~/.gefyra
mkdir -p ~/.kube
cd ~/.gefyra
touch config.ini
echo "[telemetry]" >> config.ini
echo "track = False" >> config.ini
cd ~/.kube
touch config
#
# Create a cluster with registry
#
- uses: AbsaOSS/k3d-action@v2
name: Create Single Cluster
with:
cluster-name: "mycluster"
k3d-version: v5.5.1
args: >-
--agents 1
-p "31820:31820/UDP@agent:0"
--image docker.io/rancher/k3s:${{ matrix.k3d }}
--kubeconfig-update-default
--kubeconfig-switch-context
- name: Download artifact
uses: actions/download-artifact@v4
with:
path: /tmp
- name: Load Operator image
run: |
docker load --input /tmp/pyserver/pyserver.tar
docker load --input /tmp/cargo/cargo.tar
docker load --input /tmp/operator/operator.tar
docker image ls -a
docker tag ${{ needs.build_operator.outputs.tags }} quay.io/gefyra/operator:2.1.6
- name: Import Operator to k3d
run: |
k3d image import quay.io/gefyra/operator:2.1.6 -c mycluster --verbose
- name: Pytest
working-directory: ./client
run: poetry install --with dev --no-interaction --no-root
# Run the 'Try it yourself'
- name: Apply some workload
run: |
kubectl apply -f testing/workloads/hello.yaml
- name: Run Gefyra K3D Tests
working-directory: ./client
run: |
poetry run coverage run -m pytest -vvv -s -x --full-trace --timeout=240 tests/e2e/
- name: Show gefyra-operator logs
working-directory: ./client
if: ${{ failure() }}
run: |
kubectl get pods -n gefyra
kubectl describe deployment -n gefyra gefyra-operator
kubectl describe deployment -n gefyra gefyra-operator-webhook
kubectl logs -n gefyra deployment/gefyra-operator
kubectl logs -n gefyra deployment/gefyra-operator-webhook
kubectl get -A ValidatingWebhookConfiguration
kubectl get cm -n gefyra
kubectl describe cm -n gefyra gefyra-stowaway-proxyroutes
kubectl describe cm -n gefyra gefyra-stowaway-config
kubectl describe pod -n gefyra gefyra-stowaway-0
kubectl logs -n gefyra pod/gefyra-stowaway-0
kubectl get pvc -A
kubectl describe -n gefyra pvc stowaway-config-gefyra-stowaway-0
- name: Show coverage report
working-directory: ./client
run: |
poetry run coverage report
- name: Upload coverage data to coveralls.io
if: github.repository == 'gefyrahq/gefyra'
working-directory: ./client
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}
COVERALLS_FLAG_NAME: client
COVERALLS_PARALLEL: true
run: |
poetry run coveralls --service=github-actions
- uses: actions/upload-artifact@v4
with:
name: coverage_data-${{ matrix.k3d }}
path: ./client/.coverage*
test_operator:
name: Test Gefyra Operator
runs-on: ubuntu-latest
steps:
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.9'
- name: Checkout
uses: actions/checkout@v4
- name: Install Poetry
uses: snok/install-poetry@v1
with:
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true
- name: Install dependencies
working-directory: ./operator
run: poetry install --with dev --no-interaction --no-root
- name: Install k3d
run: curl --silent --fail https://raw.githubusercontent.com/k3d-io/k3d/main/install.sh | TAG=v5.5.1 bash
- name: Run PyTest
working-directory: ./operator
run: poetry run coverage run -m pytest -s -x --retries 5
- name: Upload coverage data to coveralls.io
if: github.repository == 'gefyrahq/gefyra'
working-directory: ./operator
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}
COVERALLS_FLAG_NAME: operator
COVERALLS_PARALLEL: true
run: poetry run coveralls --service=github-actions
coveralls:
name: Indicate completion to coveralls.io
if: github.repository == 'gefyrahq/gefyra'
# need secrets.GITHUB_TOKEN
needs:
- test
- test_minikube
- test_python
- test_operator
runs-on: ubuntu-latest
container: python:3-slim
steps:
- name: Finished
run: |
pip3 install --upgrade coveralls
coveralls --service=github-actions --finish
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}