From 3e62ed09407f8df0344574a99927449f88e471da Mon Sep 17 00:00:00 2001 From: Abel Luck Date: Sun, 5 Nov 2023 21:07:50 +0100 Subject: [PATCH] add ci --- .gitlab-ci.yml | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 .gitlab-ci.yml diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml new file mode 100644 index 0000000..4ac9fe3 --- /dev/null +++ b/.gitlab-ci.yml @@ -0,0 +1,40 @@ +image: python:3.11 + +stages: + - test + - build +test: + stage: test + script: + - apt-get install -y make + - pip install poetry + - poetry install + - make check + +docker-build: + image: docker:latest + stage: build + services: + - docker:dind + variables: + GIT_SUBMODULE_STRATEGY: recursive + before_script: + - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY + # Default branch leaves tag empty (= latest tag) + # All other branches are tagged with the escaped branch name (commit ref slug) + script: + - | + if [[ "$CI_COMMIT_BRANCH" == "$CI_DEFAULT_BRANCH" ]]; then + tag="" + echo "Running on default branch '$CI_DEFAULT_BRANCH': tag = 'latest'" + else + tag=":$CI_COMMIT_REF_SLUG" + echo "Running on branch '$CI_COMMIT_BRANCH': tag = $tag" + fi + - docker build --build-arg=APP_VERSION=$CI_COMMIT_REF_SLUG -f docker/Dockerfile --pull -t "$CI_REGISTRY_IMAGE${tag}" . + - docker push "$CI_REGISTRY_IMAGE${tag}" + # Run this job in a branch where a Dockerfile exists + rules: + - if: $CI_COMMIT_BRANCH + exists: + - docker/Dockerfile