mirror of
https://github.com/bunkerity/bunkerweb
synced 2026-05-24 09:28:37 +00:00
131 lines
4.4 KiB
YAML
131 lines
4.4 KiB
YAML
name: Automatic tests (DEV)
|
|
|
|
permissions: read-all
|
|
|
|
on:
|
|
push:
|
|
branches: [dev]
|
|
|
|
jobs:
|
|
# Containers
|
|
build-containers:
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
strategy:
|
|
matrix:
|
|
image: [bunkerweb, scheduler, autoconf, ui]
|
|
include:
|
|
- image: bunkerweb
|
|
dockerfile: src/bw/Dockerfile
|
|
- image: scheduler
|
|
dockerfile: src/scheduler/Dockerfile
|
|
- image: autoconf
|
|
dockerfile: src/autoconf/Dockerfile
|
|
- image: ui
|
|
dockerfile: src/ui/Dockerfile
|
|
uses: ./.github/workflows/container-build.yml
|
|
with:
|
|
RELEASE: dev
|
|
CACHE: true
|
|
ARCH: linux/amd64
|
|
IMAGE: ${{ matrix.image }}
|
|
DOCKERFILE: ${{ matrix.dockerfile }}
|
|
secrets:
|
|
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
|
|
DOCKER_TOKEN: ${{ secrets.DOCKER_TOKEN }}
|
|
|
|
# Python code security
|
|
code-security:
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
actions: read
|
|
contents: read
|
|
security-events: write
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
language: ["python"]
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
- name: Initialize CodeQL
|
|
uses: github/codeql-action/init@v2
|
|
with:
|
|
languages: ${{ matrix.language }}
|
|
config-file: ./.github/codeql.yml
|
|
- name: Perform CodeQL Analysis
|
|
uses: github/codeql-action/analyze@v2
|
|
with:
|
|
category: "/language:${{matrix.language}}"
|
|
|
|
# UI tests
|
|
tests-ui:
|
|
needs: [code-security, build-containers]
|
|
uses: ./.github/workflows/tests-ui.yml
|
|
with:
|
|
RELEASE: dev
|
|
|
|
# Core tests
|
|
prepare-tests-core:
|
|
needs: [code-security, build-containers]
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
- id: set-matrix
|
|
run: |
|
|
tests=$(find ./tests/core/ -maxdepth 1 -mindepth 1 -type d -printf "%f\n" | jq -c --raw-input --slurp 'split("\n")| .[0:-1]')
|
|
echo "::set-output name=tests::$tests"
|
|
outputs:
|
|
tests: ${{ steps.set-matrix.outputs.tests }}
|
|
tests-core:
|
|
needs: prepare-tests-core
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
test: ${{ fromJson(needs.prepare-tests-core.outputs.tests) }}
|
|
uses: ./.github/workflows/test-core.yml
|
|
with:
|
|
TEST: ${{ matrix.test }}
|
|
RELEASE: dev
|
|
|
|
# Push with dev tag
|
|
push-dev:
|
|
needs: [tests-ui, tests-core]
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
steps:
|
|
- name: Login to Docker Hub
|
|
uses: docker/login-action@v2
|
|
with:
|
|
username: ${{ secrets.DOCKER_USERNAME }}
|
|
password: ${{ secrets.DOCKER_TOKEN }}
|
|
- name: Login to ghcr
|
|
uses: docker/login-action@v2
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
- name: Push BW image
|
|
run: docker pull ghcr.io/bunkerity/$FROM-tests:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev bunkerity/$TO:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev ghcr.io/bunkerity/$TO:dev && docker push bunkerity/$TO:dev && docker push ghcr.io/bunkerity/$TO:dev
|
|
env:
|
|
FROM: "bunkerweb"
|
|
TO: "bunkerweb"
|
|
- name: Push scheduler image
|
|
run: docker pull ghcr.io/bunkerity/$FROM-tests:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev bunkerity/$TO:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev ghcr.io/bunkerity/$TO:dev && docker push bunkerity/$TO:dev && docker push ghcr.io/bunkerity/$TO:dev
|
|
env:
|
|
FROM: "scheduler"
|
|
TO: "bunkerweb-scheduler"
|
|
- name: Push UI image
|
|
run: docker pull ghcr.io/bunkerity/$FROM-tests:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev bunkerity/$TO:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev ghcr.io/bunkerity/$TO:dev && docker push bunkerity/$TO:dev && docker push ghcr.io/bunkerity/$TO:dev
|
|
env:
|
|
FROM: "ui"
|
|
TO: "bunkerweb-ui"
|
|
- name: Push autoconf image
|
|
run: docker pull ghcr.io/bunkerity/$FROM-tests:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev bunkerity/$TO:dev && docker tag ghcr.io/bunkerity/$FROM-tests:dev ghcr.io/bunkerity/$TO:dev && docker push bunkerity/$TO:dev && docker push ghcr.io/bunkerity/$TO:dev
|
|
env:
|
|
FROM: "autoconf"
|
|
TO: "bunkerweb-autoconf"
|