Skip to content
Snippets Groups Projects
Commit 91a46f25a403 authored by Alexander Trost's avatar Alexander Trost
Browse files

Updated .gitlab-ci.yml with app review feature

parent c32beda19a49
No related branches found
No related tags found
No related merge requests found
...@@ -7,8 +7,8 @@ ...@@ -7,8 +7,8 @@
# repository in /go/src/mydomainperso.com/repos/projectname # repository in /go/src/mydomainperso.com/repos/projectname
# Thus, making a symbolic link corrects this. # Thus, making a symbolic link corrects this.
before_script: before_script:
- mkdir -p "/go/src/gitlab.zerbytes.net/${CI_PROJECT_NAMESPACE}" - mkdir -p "/go/src/gitlab.zerbytes.net/${CI_PROJECT_NAMESPACE}"
- ln -sf "${CI_PROJECT_DIR}" "/go/src/gitlab.zerbytes.net/${CI_PROJECT_PATH}" - ln -sf "${CI_PROJECT_DIR}" "/go/src/gitlab.zerbytes.net/${CI_PROJECT_PATH}"
- cd "/go/src/gitlab.zerbytes.net/${CI_PROJECT_PATH}/" - cd "/go/src/gitlab.zerbytes.net/${CI_PROJECT_PATH}/"
stages: stages:
...@@ -13,8 +13,9 @@ ...@@ -13,8 +13,9 @@
stages: stages:
- test - test
- build - build
- release - release
- deploy - review
- deploy
test: test:
...@@ -19,10 +20,10 @@ ...@@ -19,10 +20,10 @@
test: test:
stage: test stage: test
script: script:
- go get -u github.com/kardianos/govendor - go get -u github.com/kardianos/govendor
- /go/bin/govendor test +local - /go/bin/govendor test +local
test2: test2:
stage: test stage: test
script: script:
...@@ -25,8 +26,8 @@ ...@@ -25,8 +26,8 @@
test2: test2:
stage: test stage: test
script: script:
- sleep 3 - sleep 3
- echo "We did it! Something else runs in parallel!" - echo "We did it! Something else runs in parallel!"
compile: compile:
...@@ -31,14 +32,14 @@ ...@@ -31,14 +32,14 @@
compile: compile:
stage: build stage: build
variables: variables:
VERSION: "1.0.18" VERSION: "1.0.18"
script: script:
# Add here all the dependencies, or use glide/govendor/... # Add here all the dependencies, or use glide/govendor/...
# to get them automatically. # to get them automatically.
# TODO Better put this in a Makefile soon # TODO Better put this in a Makefile soon
- go build -race -ldflags "-X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.Version=$VERSION -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.Revision=${CI_COMMIT_SHA} -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.Branch=${CI_COMMIT_REF_NAME} -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.BuildUser=$(whoami)@$(hostname) -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.BuildDate=$(date +%Y%m%d-%H:%M:%S) -extldflags '-static'" -o app - go build -race -ldflags "-X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.Version=$VERSION -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.Revision=${CI_COMMIT_SHA} -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.Branch=${CI_COMMIT_REF_NAME} -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.BuildUser=$(whoami)@$(hostname) -X gitlab.zerbytes.net/${CI_PROJECT_PATH}/vendor/github.com/prometheus/common/version.BuildDate=$(date +%Y%m%d-%H:%M:%S) -extldflags '-static'" -o app
artifacts: artifacts:
paths: paths:
- app - app
...@@ -44,3 +45,3 @@ ...@@ -44,3 +45,3 @@
# example job to upload the built release to an S3 server with mc # Example job to upload the built release to a S3 server with mc
#release_upload: #release_upload:
...@@ -46,11 +47,11 @@ ...@@ -46,11 +47,11 @@
#release_upload: #release_upload:
# stage: release # stage: release
# image: minio/mc # image: minio/mc
# script: # script:
# - echo "=> We already have artifact sotrage in GitLab! This is for demonstational purposes only." # - echo "=> We already have artifact sotrage in GitLab! This is for demonstational purposes only."
# - mc config host add edenmalmoe https://s3.edenmal.net ${ACCESS_KEY} ${SECRET_KEY} S3v4 # - mc config host add edenmalmoe https://s3.edenmal.net ${ACCESS_KEY} ${SECRET_KEY} S3v4
# - mc mb -p edenmalmoe/build-release-${CI_PROJECT_NAME}/ # - mc mb -p edenmalmoe/build-release-${CI_PROJECT_NAME}/
# - mc cp app edenmalmoe/build-release-${CI_PROJECT_NAME}/ # - mc cp app edenmalmoe/build-release-${CI_PROJECT_NAME}/
image_build: image_build:
...@@ -54,17 +55,17 @@ ...@@ -54,17 +55,17 @@
image_build: image_build:
stage: release stage: release
image: docker:latest image: docker:latest
variables: variables:
DOCKER_HOST: tcp://localhost:2375 DOCKER_HOST: tcp://localhost:2375
services: services:
- docker:dind - docker:dind
script: script:
- docker info - docker info
- docker login -u gitlab-ci-token -p ${CI_JOB_TOKEN} registry.zerbytes.net - docker login -u gitlab-ci-token -p ${CI_JOB_TOKEN} registry.zerbytes.net
- docker build -t registry.zerbytes.net/${CI_PROJECT_PATH}:latest . - docker build -t registry.zerbytes.net/${CI_PROJECT_PATH}:latest .
- docker tag registry.zerbytes.net/${CI_PROJECT_PATH}:latest registry.zerbytes.net/${CI_PROJECT_PATH}:${CI_COMMIT_REF_NAME} - docker tag registry.zerbytes.net/${CI_PROJECT_PATH}:latest registry.zerbytes.net/${CI_PROJECT_PATH}:${CI_COMMIT_REF_NAME}
- test ! -z "${CI_COMMIT_TAG}" && docker push registry.zerbytes.net/${CI_PROJECT_PATH}:latest - test ! -z "${CI_COMMIT_TAG}" && docker push registry.zerbytes.net/${CI_PROJECT_PATH}:latest
- docker push registry.zerbytes.net/${CI_PROJECT_PATH}:${CI_COMMIT_REF_NAME} - docker push registry.zerbytes.net/${CI_PROJECT_PATH}:${CI_COMMIT_REF_NAME}
...@@ -70,23 +71,45 @@ ...@@ -70,23 +71,45 @@
deploy_dev: deploy_review:
image: registry.gitlab.com/gitlab-examples/kubernetes-deploy image: registry.gitlab.com/gitlab-examples/kubernetes-deploy
stage: deploy stage: review
environment: environment:
name: dev name: review/$CI_BUILD_REF_NAME
url: https://dev-presentation-gitlab-k8s.edenmal.net url: https://$CI_BUILD_REF_SLUG-presentation-gitlab-k8s.edenmal.net
script: on_stop: stop_review
- echo "${KUBE_CA_PEM}" > kube_ca.pem script:
- kubectl config set-cluster default-cluster --server=${KUBE_URL} --certificate-authority="$(pwd)/kube_ca.pem" - echo "${KUBE_CA_PEM}" > kube_ca.pem
- kubectl config set-credentials default-admin --token=${KUBE_TOKEN} - kubectl config set-cluster default-cluster --server=${KUBE_URL} --certificate-authority="$(pwd)/kube_ca.pem"
- kubectl config set-context default-system --cluster=default-cluster --user=default-admin --namespace ${KUBE_NAMESPACE} - kubectl config set-credentials default-admin --token=${KUBE_TOKEN}
- kubectl config use-context default-system - kubectl config set-context default-system --cluster=default-cluster --user=default-admin --namespace ${KUBE_NAMESPACE}
- kubectl cluster-info - kubectl config use-context default-system
- cd manifests/ - kubectl cluster-info
- sed -i "s/__CI_ENVIRONMENT_SLUG__/${CI_ENVIRONMENT_SLUG}/" deployment.yaml ingress.yaml service.yaml - cd manifests/
- sed -i "s/__VERSION__/${CI_COMMIT_REF_NAME}/" deployment.yaml ingress.yaml service.yaml - sed -i "s/__CI_ENVIRONMENT_SLUG__/${CI_ENVIRONMENT_SLUG}/" deployment.yaml ingress.yaml service.yaml
- kubectl get deployments -l app=${CI_ENVIRONMENT_SLUG} - sed -i "s/__VERSION__/${CI_COMMIT_REF_NAME}/" deployment.yaml ingress.yaml service.yaml
- if [[ $(kubectl apply -f deployment.yaml) == *"unchanged"* ]]; then kubectl patch deployment ${CI_ENVIRONMENT_SLUG} -p "{\"spec\":{\"template\":{\"metadata\":{\"annotations\":{\"ci-last-updated\":\"$(date +'%s')\"}}}}}"; fi - kubectl get deployments -l app=${CI_ENVIRONMENT_SLUG}
- kubectl apply -f service.yaml || true - if [[ $(kubectl apply -f deployment.yaml) == *"unchanged"* ]]; then kubectl patch deployment ${CI_ENVIRONMENT_SLUG} -p "{\"spec\":{\"template\":{\"metadata\":{\"annotations\":{\"ci-last-updated\":\"$(date +'%s')\"}}}}}"; fi
- kubectl apply -f ingress.yaml - kubectl apply -f service.yaml || true
- kubectl apply -f ingress.yaml
stop_review:
image: registry.gitlab.com/gitlab-examples/kubernetes-deploy
stage: review
environment:
name: review/$CI_BUILD_REF_NAME
action: stop
script:
- echo "${KUBE_CA_PEM}" > kube_ca.pem
- kubectl config set-cluster default-cluster --server=${KUBE_URL} --certificate-authority="$(pwd)/kube_ca.pem"
- kubectl config set-credentials default-admin --token=${KUBE_TOKEN}
- kubectl config set-context default-system --cluster=default-cluster --user=default-admin --namespace ${KUBE_NAMESPACE}
- kubectl config use-context default-system
- kubectl cluster-info
- cd manifests/
- sed -i "s/__CI_ENVIRONMENT_SLUG__/${CI_ENVIRONMENT_SLUG}/" deployment.yaml ingress.yaml service.yaml
- sed -i "s/__VERSION__/${CI_COMMIT_REF_NAME}/" deployment.yaml ingress.yaml service.yaml
- kubectl get deployments -l app=${CI_ENVIRONMENT_SLUG}
- kubectl delete -f deployment.yaml -f service.yaml -f ingress.yaml
- kubectl delete -f service.yaml
- kubectl delete -f ingress.yaml
deploy_live: deploy_live:
...@@ -91,24 +114,24 @@ ...@@ -91,24 +114,24 @@
deploy_live: deploy_live:
image: registry.gitlab.com/gitlab-examples/kubernetes-deploy image: registry.gitlab.com/gitlab-examples/kubernetes-deploy
stage: deploy stage: deploy
environment: environment:
name: live name: live
url: https://live-presentation-gitlab-k8s.edenmal.net url: https://live-presentation-gitlab-k8s.edenmal.net
only: only:
- tags - tags
when: manual when: manual
script: script:
- echo "${KUBE_CA_PEM}" > kube_ca.pem - echo "${KUBE_CA_PEM}" > kube_ca.pem
- kubectl config set-cluster default-cluster --server=${KUBE_URL} --certificate-authority="$(pwd)/kube_ca.pem" - kubectl config set-cluster default-cluster --server=${KUBE_URL} --certificate-authority="$(pwd)/kube_ca.pem"
- kubectl config set-credentials default-admin --token=${KUBE_TOKEN} - kubectl config set-credentials default-admin --token=${KUBE_TOKEN}
- kubectl config set-context default-system --cluster=default-cluster --user=default-admin --namespace ${KUBE_NAMESPACE} - kubectl config set-context default-system --cluster=default-cluster --user=default-admin --namespace ${KUBE_NAMESPACE}
- kubectl config use-context default-system - kubectl config use-context default-system
- kubectl cluster-info - kubectl cluster-info
- cd manifests/ - cd manifests/
- sed -i "s/__CI_ENVIRONMENT_SLUG__/${CI_ENVIRONMENT_SLUG}/" deployment.yaml ingress.yaml service.yaml - sed -i "s/__CI_ENVIRONMENT_SLUG__/${CI_ENVIRONMENT_SLUG}/" deployment.yaml ingress.yaml service.yaml
- sed -i "s/__VERSION__/${CI_COMMIT_REF_NAME}/" deployment.yaml ingress.yaml service.yaml - sed -i "s/__VERSION__/${CI_COMMIT_REF_NAME}/" deployment.yaml ingress.yaml service.yaml
- kubectl get deployments -l app=${CI_ENVIRONMENT_SLUG} - kubectl get deployments -l app=${CI_ENVIRONMENT_SLUG}
- kubectl apply -f deployment.yaml - kubectl apply -f deployment.yaml
- kubectl apply -f service.yaml || true - kubectl apply -f service.yaml || true
- kubectl apply -f ingress.yaml - kubectl apply -f ingress.yaml
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment