-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
wip: Refactor CI to use GitHub actions and generic bash scripts (#77)
- Loading branch information
Showing
6 changed files
with
181 additions
and
0 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 |
---|---|---|
@@ -0,0 +1,23 @@ | ||
name: CI | ||
on: [ push ] | ||
|
||
jobs: | ||
build_app: | ||
name: Build app | ||
if: ${{ !contains(github.event.head_commit.message, 'skip app') }} | ||
runs-on: ubuntu-22.04 | ||
steps: | ||
- name: Checkout repo | ||
uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
- name: Init runner | ||
run: bash ./scripts/init_runner.sh ${{ github.job }} | ||
- name: Setup workspace | ||
env: | ||
GITHUB_DEVELOPMENT_PAT: ${{ secrets.GH_DEVELOPMENT_PAT }} | ||
run: bash ./scripts/setup_workspace.sh | ||
- name: Build app | ||
env: | ||
SOPS_AGE_KEY: ${{ secrets.SOPS_AGE_KEY }} | ||
run: bash ./scripts/build_app.sh -p -r ${{ github.job }} |
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,3 @@ | ||
[submodule "scripts/kash"] | ||
path = scripts/kash | ||
url = https://github.com/kalisio/kash.git |
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,77 @@ | ||
#!/usr/bin/env bash | ||
set -euo pipefail | ||
# set -x | ||
|
||
THIS_FILE=$(readlink -f "${BASH_SOURCE[0]}") | ||
THIS_DIR=$(dirname "$THIS_FILE") | ||
ROOT_DIR=$(dirname "$THIS_DIR") | ||
|
||
. "$THIS_DIR/kash/kash.sh" | ||
|
||
## Parse options | ||
## | ||
|
||
PUBLISH=false | ||
CI_STEP_NAME="Build app" | ||
while getopts "pr:" option; do | ||
case $option in | ||
p) # publish app | ||
PUBLISH=true | ||
;; | ||
r) # report outcome to slack | ||
CI_STEP_NAME=$OPTARG | ||
trap 'slack_ci_report "$ROOT_DIR" "$CI_STEP_NAME" "$?" "$SLACK_WEBHOOK_SERVICES"' EXIT | ||
;; | ||
*) | ||
;; | ||
esac | ||
done | ||
|
||
## Init workspace | ||
## | ||
|
||
WORKSPACE_DIR="$(dirname "$ROOT_DIR")" | ||
init_lib_infos "$ROOT_DIR" | ||
|
||
APP=$(get_lib_name) | ||
VERSION=$(get_lib_version) | ||
GIT_TAG=$(get_lib_tag) | ||
|
||
if [[ -z "$GIT_TAG" ]]; then | ||
echo "About to build ${APP} development version..." | ||
API_VERSION=dev | ||
else | ||
echo "About to build ${APP} v${VERSION}..." | ||
API_VERSION=$(node -p -e "require(\"$ROOT_DIR/package.json\").peerDependencies['weacast-api']") | ||
fi | ||
|
||
load_env_files "$WORKSPACE_DIR/development/common/kalisio_dockerhub.enc.env" "$WORKSPACE_DIR/development/common/SLACK_WEBHOOK_SERVICES.enc.env" | ||
load_value_files "$WORKSPACE_DIR/development/common/KALISIO_DOCKERHUB_PASSWORD.enc.value" | ||
|
||
## Build container | ||
## | ||
|
||
IMAGE_NAME="weacast/weacast" | ||
if [[ -z "$GIT_TAG" ]]; then | ||
IMAGE_TAG=dev | ||
DOCKERFILE=dockerfile.dev | ||
else | ||
IMAGE_TAG=$VERSION | ||
DOCKERFILE=dockerfile | ||
fi | ||
|
||
begin_group "Building container ..." | ||
|
||
docker login --username "$KALISIO_DOCKERHUB_USERNAME" --password-stdin < "$KALISIO_DOCKERHUB_PASSWORD" | ||
# DOCKER_BUILDKIT is here to be able to use Dockerfile specific dockerginore (app.Dockerfile.dockerignore) | ||
DOCKER_BUILDKIT=1 docker build -f "$ROOT_DIR/$DOCKERFILE" \ | ||
--build-arg API_VERSION=$API_VERSION -t "$IMAGE_NAME:$IMAGE_TAG" \ | ||
"$ROOT_DIR" | ||
|
||
if [ "$PUBLISH" = true ]; then | ||
docker push "$IMAGE_NAME:$IMAGE_TAG" | ||
fi | ||
|
||
docker logout | ||
|
||
end_group "Building container ..." |
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,23 @@ | ||
#!/usr/bin/env bash | ||
set -euo pipefail | ||
# set -x | ||
|
||
JOB_ID=$1 | ||
|
||
THIS_FILE=$(readlink -f "${BASH_SOURCE[0]}") | ||
THIS_DIR=$(dirname "$THIS_FILE") | ||
# ROOT_DIR=$(dirname "$THIS_DIR") | ||
|
||
. "$THIS_DIR/kash/kash.sh" | ||
|
||
### Github Actions | ||
|
||
init_github_build_app() { | ||
install_reqs age sops nvm node16 | ||
} | ||
|
||
begin_group "Init $CI_ID for $JOB_ID" | ||
|
||
init_"${CI_ID}_${JOB_ID}" | ||
|
||
end_group "Init $CI_ID for $JOB_ID" |
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,54 @@ | ||
#!/usr/bin/env bash | ||
set -euo pipefail | ||
# set -x | ||
|
||
THIS_FILE=$(readlink -f "${BASH_SOURCE[0]}") | ||
THIS_DIR=$(dirname "$THIS_FILE") | ||
ROOT_DIR=$(dirname "$THIS_DIR") | ||
|
||
. "$THIS_DIR/kash/kash.sh" | ||
|
||
## Parse options | ||
## | ||
|
||
WORKSPACE_BRANCH= | ||
WORKSPACE_TAG= | ||
|
||
begin_group "Setting up workspace ..." | ||
|
||
if [ "$CI" = true ]; then | ||
WORKSPACE_DIR="$(dirname "$ROOT_DIR")" | ||
DEVELOPMENT_REPO_URL="https://$GITHUB_DEVELOPMENT_PAT@github.com/kalisio/development.git" | ||
else | ||
while getopts "b:t" option; do | ||
case $option in | ||
b) # defines branch | ||
WORKSPACE_BRANCH=$OPTARG;; | ||
t) # defines tag | ||
WORKSPACE_TAG=$OPTARG;; | ||
*) | ||
;; | ||
esac | ||
done | ||
shift $((OPTIND-1)) | ||
WORKSPACE_DIR="$1" | ||
|
||
# NOTE: cloning weacast could be avoided if we could parse app_version from tag/branch name instead | ||
# In this case, the kli would clone weacast | ||
GIT_OPS="--recurse-submodules" | ||
if [ -n "$WORKSPACE_TAG" ] || [ -n "$WORKSPACE_BRANCH" ]; then | ||
GIT_OPS="$GIT_OPS --branch ${WORKSPACE_TAG:-$WORKSPACE_BRANCH}" | ||
fi | ||
git clone --depth 1 $GIT_OPS "$GITHUB_URL/weacast/weacast-app.git" "$WORKSPACE_DIR/weacast-app" | ||
|
||
DEVELOPMENT_REPO_URL="$GITHUB_URL/kalisio/development.git" | ||
|
||
# unset KALISIO_DEVELOPMENT_DIR because we want kli to clone everything in $WORKSPACE_DIR | ||
unset KALISIO_DEVELOPMENT_DIR | ||
fi | ||
|
||
# clone development in $WORKSPACE_DIR | ||
DEVELOPMENT_DIR="$WORKSPACE_DIR/development" | ||
git clone --depth 1 "$DEVELOPMENT_REPO_URL" "$DEVELOPMENT_DIR" | ||
|
||
end_group "Setting up workspace ..." |