1.5.0 #4
Workflow file for this run
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
name: Release | |
on: | |
release: | |
types: [published] | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
services: | |
memcached: | |
image: memcached:1.4.31 | |
ports: | |
- 11211/tcp | |
env: | |
ES_HOST: ${{ secrets.RE3DATA_ES_HOST }} | |
ELASTIC_USER: ${{ secrets.RE3DATA_ES_USER }} | |
ELASTIC_PASSWORD: ${{ secrets.RE3DATA_ES_PASSWORD }} | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Set up Ruby 3.1.4 | |
uses: actions/setup-ruby@v1 | |
with: | |
ruby-version: '3.1.4' | |
- uses: actions/cache@v2 | |
with: | |
path: vendor/bundle | |
key: ${{ runner.os }}-gems-${{ hashFiles('**/Gemfile.lock') }} | |
restore-keys: | | |
${{ runner.os }}-gems- | |
- name: Install | |
run: | | |
gem install bundler | |
bundle config set --local path 'vendor/bundle' | |
bundle install --jobs 4 --retry 3 | |
- name: Lint and Test | |
env: | |
MEMCACHE_SERVERS: "localhost:${{ job.services.memcached.ports[11211] }}" | |
ES_HOST: ${{ secrets.RE3DATA_ES_HOST }} | |
ELASTIC_USER: ${{ secrets.RE3DATA_ES_USER }} | |
ELASTIC_PASSWORD: ${{ secrets.RE3DATA_ES_PASSWORD }} | |
run: | | |
# bundle exec rubocop | |
bundle exec rspec | |
echo $? | |
- name: Publish code coverage | |
uses: paambaati/[email protected] | |
env: | |
CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }} | |
build: | |
needs: test | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v1 | |
- name: Cache Docker layers | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/.buildx-cache | |
key: ${{ runner.os }}-buildx-${{ github.sha }} | |
restore-keys: | | |
${{ runner.os }}-buildx- | |
- name: Login to DockerHub | |
uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v1 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Get git tag | |
run: | | |
echo "::set-output name=GIT_TAG::$(git tag --points-at HEAD)" | |
id: set_git_vars | |
- name: Push to Docker Hub | |
uses: docker/build-push-action@v2 | |
with: | |
context: . | |
file: ./Dockerfile | |
push: true | |
tags: ${{ github.repository }}:${{ steps.set_git_vars.outputs.GIT_TAG }} | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache | |
- name: Push to GitHub Packages | |
uses: docker/build-push-action@v2 | |
with: | |
context: . | |
file: ./Dockerfile | |
push: true | |
tags: ghcr.io/${{ github.repository }}:${{ steps.set_git_vars.outputs.GIT_TAG }} | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache | |
deploy: | |
needs: [test, build] | |
runs-on: ubuntu-latest | |
env: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
- name: Extract variables | |
shell: bash | |
run: | | |
echo "::set-output name=BRANCH::$(echo ${GITHUB_REF#refs/heads/} | sed 's/\//_/g')" | |
echo "::set-output name=GIT_TAG::$(git tag --points-at HEAD)" | |
echo "::set-output name=GIT_SHA::$(git rev-parse HEAD)" | |
echo "::set-output name=GIT_SHA_SHORT::$(git rev-parse --short HEAD)" | |
id: extract_variables | |
- name: Checkout terraform config repo | |
uses: actions/checkout@v2 | |
with: | |
# public repo with terraform configuration | |
repository: 'datacite/mastino' | |
persist-credentials: false | |
- name: Commit changes to terraform config repository | |
# use go template in terraform config repository to update git sha and tag | |
# commit and push changes to trigger terraform workflow | |
run: | | |
export GIT_SHA=${{ steps.extract_variables.outputs.GIT_SHA_SHORT }} | |
export GIT_TAG=${{ steps.extract_variables.outputs.GIT_TAG }} | |
wget https://github.com/jwilder/dockerize/releases/download/v0.6.0/dockerize-linux-amd64-v0.6.0.tar.gz | |
tar -xzvf dockerize-linux-amd64-v0.6.0.tar.gz | |
rm dockerize-linux-amd64-v0.6.0.tar.gz | |
./dockerize -template prod-eu-west/services/re3data/_schnauzer.auto.tfvars.tmpl:prod-eu-west/services/re3data/_schnauzer.auto.tfvars | |
git config --local user.email "[email protected]" | |
git config --local user.name "GitHub Action" | |
git add prod-eu-west/services/re3data/_schnauzer.auto.tfvars | |
git commit -m "Adding schnauzer git variables for commit ${{ steps.extract_variables.outputs.GIT_TAG }}" | |
- name: Push changes | |
uses: ad-m/[email protected] | |
with: | |
github_token: ${{ secrets.PERSONAL_ACCESS_TOKEN }} | |
repository: 'datacite/mastino' | |
branch: 'refs/heads/master' | |
tags: false | |
- name: Notify Slack | |
uses: edge/simple-slack-notify@master | |
with: | |
channel: '#ops' | |
color: 'good' | |
text: 'Version <https://github.com/${{ github.repository }}/releases/tag/${{ steps.extract_variables.outputs.GIT_TAG }}|${{ steps.extract_variables.outputs.GIT_TAG }}> of the Re3data API has been deployed to production.' | |
failure_text: '${env.GITHUB_WORKFLOW} (${env.GITHUB_RUN_NUMBER}) build failed' | |
fields: | | |
[{ "title": "Committed by", "value": "<https://github.com/${{ github.repository }}/commits?author=${{ github.actor }}|${{ github.actor }}>", "short": true }, | |
{ "title": "Commit SHA", "value": "<https://github.com/${{ github.repository }}/commit/${{ steps.extract_variables.outputs.GIT_SHA }}|${{ steps.extract_variables.outputs.GIT_SHA_SHORT }}>", "short": true }, | |
{ "title": "Repository", "value": "<https://github.com/${{ github.repository }}|${{ github.repository }}>", "short": true }, | |
{ "title": "Release", "value": "<https://github.com/${{ github.repository }}/releases/tag/${{ steps.extract_variables.outputs.GIT_TAG }}|${{ steps.extract_variables.outputs.GIT_TAG }}>", "short": true }] |