generated from EVerest/everest-template
-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Refactor docker images and workflows to build and deploy them
* Remove workflow `deploy-build-kit.yaml`. It is integrated into `deploy-docker-images.yml`. * Refactor deploy-docker-images.yml workflow * Convert matrix into multiple jobs, one for each docker image, because the images depend on each other, and the matrix strategy does not support this. * Add `env-setup` job to set up the environment for the other jobs, because reusable workflows don't support environment variables. * Add input parameter to build deprecated images. Currently, the deprecated images are built by default, if not specified otherwise. * Refactor build-single-docker-image.yml * Rename input `docker_directory` to `directory`. Instead of setting the directory that contains all images, it is set now to the directory that contains the Dockerfile for the image to build. * Add input parameter `docker_file_name` to specify the Dockerfile to use. * Add input parameter `platforms` to specify the platforms to build the image for. The default is `linux/amd64,linux/arm64` and `linux/arm/v7`. * The name of the deployed image is now set by the input parameter `image_name`: `ghcr.io/everest/<image_name>`. The directory name is independent of the image name. * Update README.md * Move `ghcr.io/everest/everest-clan-format` to `ghcr.io/everest/everest-ci/everest-clang-format`. The old image is deprecated, but still available and deployed. * Merge `ghcr.io/everest/build-kit-alpine` and `ghcr.io/everest/build-kit-debian` into `ghcr.io/everest/everest-ci/build-kit`. The old images are deprecated, but still available and deployed. * Add `ghcr.io/everest/everest-ci/run-env-base` image * Add `ghcr.io/everest/everest-ci/build-env-base` image * Add `ghcr.io/everest/everest-ci/dev-env-base` image Signed-off-by: Andreas Heinrich <[email protected]>
- Loading branch information
Showing
14 changed files
with
907 additions
and
22 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,6 +7,10 @@ on: | |
description: 'Force rebuild of all images' | ||
default: false | ||
type: boolean | ||
build_deprecated_images: | ||
description: 'Build deprecated images' | ||
default: false | ||
type: boolean | ||
push: | ||
branches: | ||
- '**' | ||
|
@@ -15,21 +19,171 @@ on: | |
|
||
env: | ||
REGISTRY: ghcr.io | ||
DOCKER_DIRECTORY: docker/images/ | ||
PLATFORMS: | | ||
linux/amd64 | ||
# linux/arm64 | ||
# linux/arm/v7 | ||
|
||
jobs: | ||
build-and-push-all-images: | ||
name: Build and push all docker images | ||
strategy: | ||
matrix: | ||
image_name: [everest-clang-format] | ||
uses: everest/everest-ci/.github/workflows/[email protected] | ||
env-setup: | ||
# Since env variables can't be passed to reusable workflows, we need to pass them as outputs | ||
name: Evaluate force rebuild and set env variables as outputs | ||
runs-on: ubuntu-22.04 | ||
outputs: | ||
force_rebuild: ${{ steps.check.outputs.force_rebuild }} | ||
docker_registry: ${{ steps.check.outputs.docker_registry }} | ||
docker_directory: ${{ steps.check.outputs.docker_directory }} | ||
platforms: ${{ steps.check.outputs.platforms }} | ||
repository_name: ${{ steps.check.outputs.repository_name }} | ||
build_deprecated_images: ${{ github.event.inputs.build_deprecated_images }} | ||
steps: | ||
- id: check | ||
run: | | ||
echo "force_rebuild=${{ inputs.force_rebuild || (github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/' )) || false }}" >> $GITHUB_OUTPUT | ||
echo "docker_registry=${{ env.REGISTRY }}" >> $GITHUB_OUTPUT | ||
echo "docker_directory=${{ env.DOCKER_DIRECTORY }}" >> $GITHUB_OUTPUT | ||
echo "platforms=${{ env.PLATFORMS }}" >> $GITHUB_OUTPUT | ||
echo "repository_name=${{ github.event.repository.name }}" >> $GITHUB_OUTPUT | ||
# Build deprecated images if not explicitly disabled | ||
#TODO: set default to false, once backwards compatibility is no longer needed | ||
echo "build_deprecated_images=${{ inputs.build_deprecated_images || true }}" >> $GITHUB_OUTPUT | ||
# One job for each image, since the images build on top of each other a matrix strategy is not possible | ||
everest-clang-format: | ||
needs: | ||
- env-setup | ||
name: Build and push everest-clang-format docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: ${{ needs.env-setup.outputs.repository_name }}/everest-clang-format | ||
directory: ${{ needs.env-setup.outputs.docker_directory }}/everest-clang-format | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
run-env-base: | ||
needs: | ||
- env-setup | ||
name: Build and push run-env-base docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ inputs.force_rebuild || (github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/' )) || false }} | ||
image_name: ${{ matrix.image_name }} | ||
docker_directory: docker/images/ | ||
docker_registry: ghcr.io | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: ${{ needs.env-setup.outputs.repository_name }}/run-env-base | ||
directory: ${{ needs.env-setup.outputs.docker_directory }}/run-env-base | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
build-env-base: | ||
needs: | ||
- env-setup | ||
- run-env-base | ||
name: Build and push build-env-base docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: ${{ needs.env-setup.outputs.repository_name }}/build-env-base | ||
directory: ${{ needs.env-setup.outputs.docker_directory }}/build-env-base | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
dev-env-base: | ||
needs: | ||
- env-setup | ||
- build-env-base | ||
name: Build and push dev-env-base docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: ${{ needs.env-setup.outputs.repository_name }}/dev-env-base | ||
directory: ${{ needs.env-setup.outputs.docker_directory }}/dev-env-base | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
build-kit: | ||
needs: | ||
- env-setup | ||
- build-env-base | ||
name: Build and push build-kit docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: ${{ needs.env-setup.outputs.repository_name }}/build-kit | ||
directory: ${{ needs.env-setup.outputs.docker_directory }}/build-kit | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
# Include deprecated images for backwards compatibility | ||
deprecated-everest-clang-format: | ||
if: ${{ needs.env-setup.outputs.build_deprecated_images == 'true' }} | ||
needs: | ||
- env-setup | ||
name: Build and push deprecated everest-clang-format docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: everest-clang-format | ||
directory: docker/deprecated-images/everest-clang-format | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
deprecated-build-kit-alpine: | ||
if: ${{ needs.env-setup.outputs.build_deprecated_images == 'true' }} | ||
needs: | ||
- env-setup | ||
name: Build and push deprecated build-kit-alpine docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: build-kit-alpine | ||
directory: docker/deprecated-images/build-kit | ||
docker_file_name: alpine.Dockerfile | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} | ||
deprecated-build-kit-debian: | ||
if: ${{ needs.env-setup.outputs.build_deprecated_images == 'true' }} | ||
needs: | ||
- env-setup | ||
name: Build and push deprecated build-kit-debian docker image | ||
uses: ./.github/workflows/deploy-single-docker-image.yml | ||
secrets: | ||
SA_GITHUB_PAT: ${{ secrets.SA_GITHUB_PAT }} | ||
SA_GITHUB_USERNAME: ${{ secrets.SA_GITHUB_USERNAME }} | ||
with: | ||
force_rebuild: ${{ needs.env-setup.outputs.force_rebuild == 'true' }} | ||
image_name: build-kit-debian | ||
directory: docker/deprecated-images/build-kit | ||
docker_file_name: debian.Dockerfile | ||
docker_registry: ${{ needs.env-setup.outputs.docker_registry }} | ||
github_ref_before: ${{ github.event.before }} | ||
github_ref_after: ${{ github.event.after }} | ||
platforms: ${{ needs.env-setup.outputs.platforms }} |
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,56 @@ | ||
# everest ci/cd | ||
# EVerest CI/CD | ||
|
||
This repository should share all common used functionality for the | ||
everest github ci/cd pipe | ||
|
||
## Docker Images | ||
|
||
### run-env-base | ||
|
||
Based on `debian:12-slim`. | ||
|
||
Deployed as `ghcr.io/everest/everest-ci/run-env-base`. | ||
|
||
Includes all dependencies that are necessary to run EVerest. | ||
|
||
### build-env-base | ||
|
||
Based on `run-env-base`. | ||
|
||
Deployed as `ghcr.io/everest/everest-ci/build-env-base`. | ||
|
||
Includes all dependencies that are necessary to build EVerest. | ||
|
||
### dev-env-base | ||
|
||
Based on `build-env-base`. | ||
|
||
Deployed as `ghcr.io/everest/everest-ci/dev-env-base`. | ||
|
||
Include additional packages to develop EVerest. | ||
|
||
### everest-clang-format | ||
|
||
> [!NOTE] | ||
> This image was moved from `ghcr.io/everest/clang-format` to | ||
> `ghcr.io/everest/everest-ci/everest-clang-format`. The old image is | ||
> deprecated and will be removed in the future. | ||
Deployed as `ghcr.io/everest/everest-ci/everest-clang-format`. | ||
|
||
Contains a fixed clang-format version in addition to a run-clang-format script. This image can be diretcly executed. | ||
This image is used as base for a custom github action and can also be used to run clang-format locally. | ||
|
||
### build-kit | ||
|
||
> [!NOTE] | ||
> The images `ghcr.io/everest/build-kit-alpine` and `ghcr.io/everest/build-kit-debian` | ||
> are deprecated and will be removed in the future. Please use | ||
> `ghcr.io/everest/everest-ci/> build-kit` instead. | ||
Based on `build-env-base`. | ||
|
||
Deployed as `ghcr.io/everest/everest-ci/build-kit`. | ||
|
||
This image includes a mechanic to run bash scripts in the build environment. It is used to run the build scripts in the CI/CD pipeline. | ||
It is executed directly. |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
doc.rst |
File renamed without changes.
File renamed without changes.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
#!/bin/sh | ||
|
||
setup_cache(){ | ||
export CPM_SOURCE_CACHE=$EXT_MOUNT/cache/cpm | ||
export CCACHE_DIR=$EXT_MOUNT/cache/ccache | ||
|
||
maven_cache_dir=$EXT_MOUNT/cache/m2-repo | ||
|
||
# we copy the settings file each time in case the $HOME folder changes | ||
mkdir -p $HOME/.m2 || true | ||
cp $ASSETS_PATH/maven-settings.xml $HOME/.m2/settings.xml | ||
sed -i 's@MAVEN_CACHE_REPOSITORY@'"$maven_cache_dir"'@' $HOME/.m2/settings.xml | ||
} | ||
|
||
# if first cmd is exec we're going to exec what follows | ||
# otherwise check for script | ||
run_script(){ | ||
|
||
if [ "$1" = 'run-script' ]; then | ||
|
||
if [ -z "$2" ]; then | ||
echo "Error: missing script name for run-script mode" | ||
exit 1 | ||
fi | ||
|
||
init_script=$EXT_MOUNT/scripts/$2.sh | ||
|
||
if [ ! -f "$init_script" ]; then | ||
echo "Error: no script found at $init_script" | ||
# bash convention, 127 = not found | ||
exit 127 | ||
fi | ||
|
||
exec $init_script | ||
fi | ||
|
||
# not the run-script mode | ||
exec "$@" | ||
|
||
} | ||
|
||
setup_cache | ||
run_script $@ | ||
|
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
<settings xmlns="http://maven.apache.org/SETTINGS/1.2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.2.0 http://maven.apache.org/xsd/settings-1.2.0.xsd"> | ||
<localRepository>MAVEN_CACHE_REPOSITORY</localRepository> | ||
</settings> |
Oops, something went wrong.