Semaphore/.circleci/config.yml

295 lines
8.1 KiB
YAML
Raw Normal View History

# Workflow based configuration
2018-03-12 01:35:24 +01:00
version: 2
aliases:
2020-10-03 16:35:15 +02:00
# - &get-code
# run:
# name: Get code
# command: |
# git clone -b $CIRCLE_BRANCH https://github.com/ansible-semaphore/semaphore.git ./
- &golang-image
2021-08-26 11:22:52 +02:00
image: circleci/golang:1.16
- &working-dir
/go/src/github.com/ansible-semaphore/semaphore
- &store-bin-artifacts
store_artifacts:
path: /go/src/github.com/ansible-semaphore/semaphore/bin
- &install-task-binary
run:
name: install task binary
2020-02-09 14:48:24 +01:00
# subshell prevents potentially unwanted cwd change
2021-10-11 19:28:31 +02:00
command: go get github.com/go-task/task/v3/cmd/task
2021-10-11 18:17:50 +02:00
# command: (cd $HOME && (curl -sL https://taskfile.dev/install.sh | ~))
- &persist-from-build
persist_to_workspace:
root: .
paths:
- bin/*
- &install-node
run:
name: Install node
command: |
set +e
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.5/install.sh | bash
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"
2020-02-09 15:42:55 +01:00
nvm install 12.15.0 && nvm alias default 12.15.0
# Each step uses the same `$BASH_ENV`, so need to modify it
echo 'export NVM_DIR="$HOME/.nvm"' >> $BASH_ENV
echo "[ -s \"$NVM_DIR/nvm.sh\" ] && . \"$NVM_DIR/nvm.sh\"" >> $BASH_ENV
2018-04-07 00:50:17 +02:00
- &unlock-gpg
run:
name: unlock gpg key, trying to do this in the goreleaser step with env vars does not seem to work
command: |
echo $GPG_KEY | tr " " "\n" | base64 -d | gpg --import --batch
2020-10-03 15:55:31 +02:00
gpg --sign -u "8CDE D132 5E96 F1D9 EABF 17D4 2C96 CF7D D27F AB82" --pinentry-mode loopback --yes --batch --passphrase "${GPG_PASS}" --output unlock.sig --detach-sign README.md
2018-04-07 00:50:17 +02:00
rm -f unlock.sig
- &test-compile-changes
run:
name: test that compile did not create/modify untracked files
2021-03-12 21:47:16 +01:00
command: |
git diff --exit-code --stat -- . ':(exclude)web2/package.json' ':(exclude)web2/package-lock.json' ':(exclude)go.mod' ':(exclude)go.sum'
- &save-npm-cache
save_cache:
2021-06-24 21:55:26 +02:00
key: v1-npm-deps-{{ checksum "web2/package.json" }}
paths:
2021-06-24 21:55:26 +02:00
- web2/node_modules
- &save-go-cache
save_cache:
2020-02-09 16:00:50 +01:00
key: v1-go-deps-{{ checksum "go.sum" }}-{{ checksum "go.mod" }}
paths:
- vendor
- &load-npm-cache
restore_cache:
keys:
2021-06-24 21:55:26 +02:00
- v1-npm-deps-{{ checksum "web2/package.json" }}
- v1-npm-deps-
- &load-go-cache
restore_cache:
keys:
2020-02-09 16:00:50 +01:00
- v1-go-deps-{{ checksum "go.sum" }}-{{ checksum "go.mod" }}
- v1-go-deps-{{ checksum "go.sum" }}
- v1-go-deps-
2018-03-12 01:35:24 +01:00
jobs:
build:local:
docker:
- *golang-image
working_directory: *working-dir
steps:
- *install-node
- *install-task-binary
2020-10-03 16:35:15 +02:00
- checkout
- *load-go-cache
- *load-npm-cache
- run: task deps
- *save-go-cache
- *save-npm-cache
- run: task compile
- *test-compile-changes
- run: task build:local
- *store-bin-artifacts
- *persist-from-build
2018-03-12 01:35:24 +01:00
build:
docker:
- *golang-image
working_directory: *working-dir
steps:
- *install-node
- *install-task-binary
2021-08-11 18:51:05 +02:00
- run: sudo apt update && sudo apt-get install rpm
2020-10-03 16:35:15 +02:00
- checkout
- *load-go-cache
- *load-npm-cache
- run: task deps
- run: task compile
- *test-compile-changes
2020-10-02 23:41:45 +02:00
- *unlock-gpg
- run: task build
- *store-bin-artifacts
test:integration:hooks:
docker:
- *golang-image
working_directory: *working-dir
steps:
2020-10-03 16:35:15 +02:00
- checkout
- *install-node
- *install-task-binary
- run: task deps:integration
- run: task deps:tools
- run: task deps:be
- run: task compile:be
- run: task compile:api:hooks
- store_artifacts:
path: /go/src/github.com/ansible-semaphore/semaphore/.dredd/compiled_hooks
# Run goverage and post results
test:golang:
docker:
- *golang-image
working_directory: *working-dir
2018-03-12 01:35:24 +01:00
steps:
- *install-task-binary
# Needed only in ci to post coverage reports
- run: go get github.com/schrej/godacov
2020-10-03 16:35:15 +02:00
- checkout
- *load-go-cache
- run: task deps:tools
- run: task deps:be
- run: task compile:be
- run: task lint:be
- run: task test
- run: godacov -t "${CODACY_TOKEN}" -r ./coverage.out -c "${CIRCLE_SHA1}" || true
- store_test_results:
path: /go/src/github.com/ansible-semaphore/semaphore/coverage.out
- store_artifacts:
path: /go/src/github.com/ansible-semaphore/semaphore/coverage.out
test:integration:
2021-10-11 19:28:31 +02:00
machine:
image: ubuntu-2004:202107-02
steps:
2020-10-03 16:35:15 +02:00
- checkout
2020-02-09 15:42:55 +01:00
- *install-task-binary
- run: context=ci task dc:up
test:db:migration:
docker:
- *golang-image
2018-05-07 12:05:49 +02:00
- image: circleci/mysql:5.6
working_directory: *working-dir
steps:
- *install-task-binary
- *install-node
- attach_workspace:
at: *working-dir
# This looks like utter filth in circleci v2 but we have no choice apart from this escaping madness
- run: "cat > config.json <<EOF\n{\n\t\"mysql\": {\n\t\t\"host\": \"127.0.0.1:3306\"\
,\n\t\t\"user\": \"root\",\n\t\t\"pass\": \"\",\n\t\t\"name\": \"circle_test\"\
\n\t},\n\t\"email_alert\": false\n}\nEOF\n"
- run:
name: Wait for db
command: dockerize -wait tcp://127.0.0.1:3306 -timeout 1m
- run: bin/semaphore migrate --config config.json
test:docker:
docker:
- *golang-image
steps:
- *install-task-binary
2020-10-03 16:35:15 +02:00
- checkout
- setup_remote_docker
- run: context=prod task docker:test
deploy:dev:
docker:
- *golang-image
steps:
- *install-task-binary
2020-10-03 16:35:15 +02:00
- checkout
- setup_remote_docker
- run: docker login -u $DOCKER_USER -p $DOCKER_PASS
- run: context=prod tag=develop task docker:build
- run: tag=develop task docker:push
deploy:prod:
docker:
- *golang-image
steps:
- *install-task-binary
2020-10-03 16:35:15 +02:00
- checkout
- setup_remote_docker
- run: docker login -u $DOCKER_USER -p $DOCKER_PASS
- run: context=prod tag=latest task docker:build
- run: tag=latest task docker:push
2018-04-07 00:50:17 +02:00
- run: docker tag ansiblesemaphore/semaphore:latest ansiblesemaphore/semaphore:$CIRCLE_TAG
- run: tag=$CIRCLE_TAG task docker:push
2018-04-07 00:50:17 +02:00
# For releases to work in the ci you will need to have the following env vars set
# GITHUB_TOKEN - token needs writes to make a release
# GPG_PASS - password for the GP key to sign releases with, circleci sets env vars with "" so be wary of special chars
# GPG_KEY - base64 encoded version of the GPG private key
release:
docker:
- *golang-image
working_directory: *working-dir
steps:
- *install-node
- *install-task-binary
2021-08-11 18:51:05 +02:00
- run: sudo apt update && sudo apt-get install rpm
2020-10-03 16:35:15 +02:00
- checkout
- *load-go-cache
- *load-npm-cache
- run: task deps
2018-04-07 00:50:17 +02:00
- *unlock-gpg
- run:
name: reset repo as npm install may have changed lock file
command: git reset --hard
- run: task release:prod
- *store-bin-artifacts
workflows:
version: 2
build-test:
jobs:
- test:docker
- test:golang
- test:integration:hooks
- test:integration
- build:local
- test:db:migration:
requires:
- build:local
# Don't build on master because build is just a gorelease without the release
- build:
requires:
- test:golang
- test:db:migration
- test:integration
filters:
branches:
ignore: master
# Dev deploys require all tests to pass and app builds
- deploy:dev:
requires:
- build
- test:docker
filters:
branches:
only: develop
# Production deploys only happen if everything passes
# and we have a tag starting with v
- release:
filters:
branches:
ignore: /.*/
tags:
only: /^v.*/
- deploy:prod:
filters:
branches:
ignore: /.*/
tags:
only: /^v.*/