name: Automatic tests (DEV) permissions: read-all on: push: branches: [dev] jobs: # Containers build-containers: permissions: contents: read packages: write strategy: fail-fast: false 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 ARCH: linux/amd64 CACHE: true IMAGE: ${{ matrix.image }} DOCKERFILE: ${{ matrix.dockerfile }} secrets: DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} DOCKER_TOKEN: ${{ secrets.DOCKER_TOKEN }} # Build Linux packages build-packages: permissions: contents: read packages: write strategy: matrix: linux: [ubuntu, ubuntu-noble, debian, fedora, rhel, rhel9] include: - linux: ubuntu package: deb - linux: ubuntu-noble package: deb - linux: debian package: deb - linux: fedora package: rpm - linux: rhel package: rpm - linux: rhel9 package: rpm uses: ./.github/workflows/linux-build.yml with: RELEASE: dev LINUX: ${{ matrix.linux }} PACKAGE: ${{ matrix.package }} TEST: true PLATFORMS: linux/amd64 secrets: DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} DOCKER_TOKEN: ${{ secrets.DOCKER_TOKEN }} codeql: uses: ./.github/workflows/codeql.yml permissions: actions: read contents: read security-events: write # UI tests prepare-tests-ui: runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6 - id: set-matrix run: | tests=$(find ./tests/ui/ -name "*_page.py" -type f -printf "%f\n" | jq -c --raw-input --slurp 'split("\n")| .[0:-1]') echo "tests=$tests" >> $GITHUB_OUTPUT outputs: tests: ${{ steps.set-matrix.outputs.tests }} tests-ui: needs: [prepare-tests-ui, build-containers] strategy: fail-fast: false matrix: test: ${{ fromJson(needs.prepare-tests-ui.outputs.tests) }} uses: ./.github/workflows/tests-ui.yml with: TEST: ${{ matrix.test }} RELEASE: dev tests-ui-linux: needs: [prepare-tests-ui, build-packages] strategy: fail-fast: false matrix: test: ${{ fromJson(needs.prepare-tests-ui.outputs.tests) }} uses: ./.github/workflows/tests-ui-linux.yml with: TEST: ${{ matrix.test }} RELEASE: dev # Core tests prepare-tests-core: runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6 - 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 "tests=$tests" >> $GITHUB_OUTPUT outputs: tests: ${{ steps.set-matrix.outputs.tests }} tests-core: needs: [build-containers, 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 tests-core-linux: needs: [build-packages, prepare-tests-core] strategy: fail-fast: false matrix: test: ${{ fromJson(needs.prepare-tests-core.outputs.tests) }} uses: ./.github/workflows/test-core-linux.yml with: TEST: ${{ matrix.test }} RELEASE: dev secrets: inherit # 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@e92390c5fb421da1463c202d546fed0ec5c39f20 # v3.1.0 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - name: Login to ghcr uses: docker/login-action@e92390c5fb421da1463c202d546fed0ec5c39f20 # v3.1.0 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" # Push Linux packages push-packages: needs: [tests-ui-linux, tests-core-linux] strategy: matrix: linux: [ubuntu, ubuntu-noble, debian, fedora, el, el9] arch: [amd64] include: - release: dev repo: bunkerweb - linux: ubuntu package_arch: amd64 separator: _ suffix: "" version: jammy package: deb - linux: ubuntu-noble package_arch: amd64 separator: _ suffix: "" version: noble package: deb - linux: debian package_arch: amd64 separator: _ suffix: "" version: bookworm package: deb - linux: fedora package_arch: x86_64 separator: "-" suffix: "1." version: 39 package: rpm - linux: el package_arch: x86_64 separator: "-" suffix: "1." version: 8 package: rpm - linux: el9 package_arch: x86_64 separator: "-" suffix: "1." version: 9 package: rpm uses: ./.github/workflows/push-packagecloud.yml with: SEPARATOR: ${{ matrix.separator }} SUFFIX: ${{ matrix.suffix }} REPO: ${{ matrix.repo }} LINUX: ${{ matrix.linux }} VERSION: ${{ matrix.version }} PACKAGE: ${{ matrix.package }} BW_VERSION: ${{ matrix.release }} PACKAGE_ARCH: ${{ matrix.package_arch }} ARCH: ${{ matrix.arch }} secrets: PACKAGECLOUD_TOKEN: ${{ secrets.PACKAGECLOUD_TOKEN }}