# Workflow based configuration version: 2 aliases: # - &get-code # run: # name: Get code # command: | # git clone -b $CIRCLE_BRANCH https://github.com/ansible-semaphore/semaphore.git ./ - &golang-image image: circleci/golang:1.13 - &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 # subshell prevents potentially unwanted cwd change command: (cd $HOME && (curl -sL https://taskfile.dev/install.sh | 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" 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 - &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 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 rm -f unlock.sig - &test-compile-changes run: name: test that compile did not create/modify untracked files command: git diff --exit-code --stat -- . ':(exclude)web2/package-lock.json' ':(exclude)web/package-lock.json' ':(exclude)go.mod' ':(exclude)go.sum' - &save-npm-cache save_cache: key: v1-npm-deps-{{ checksum "web/package.json" }} paths: - web/node_modules - &save-go-cache save_cache: key: v1-go-deps-{{ checksum "go.sum" }}-{{ checksum "go.mod" }} paths: - vendor - &load-npm-cache restore_cache: keys: - v1-npm-deps-{{ checksum "web/package.json" }} - v1-npm-deps- - &load-go-cache restore_cache: keys: - v1-go-deps-{{ checksum "go.sum" }}-{{ checksum "go.mod" }} - v1-go-deps-{{ checksum "go.sum" }} - v1-go-deps- jobs: build:local: docker: - *golang-image working_directory: *working-dir steps: - *install-node - *install-task-binary - 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 build: docker: - *golang-image working_directory: *working-dir steps: - *install-node - *install-task-binary - run: sudo apt-get install rpm - checkout - *load-go-cache - *load-npm-cache - run: task deps - run: task compile - *test-compile-changes - *unlock-gpg - run: task build - *store-bin-artifacts test:integration:hooks: docker: - *golang-image working_directory: *working-dir steps: - 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 steps: - *install-task-binary # Needed only in ci to post coverage reports - run: go get github.com/schrej/godacov - 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: machine: true steps: - checkout - *install-task-binary - run: context=ci task dc:up test:db:migration: docker: - *golang-image - 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 <