-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rework github workflows for staging deploy
Use shared workflows and refactor deployment code. Dropping support for dockerhub images. Test workflow is now shared test workflow.
- Loading branch information
1 parent
78b09f5
commit ab31465
Showing
5 changed files
with
149 additions
and
172 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
name: Build Docker | ||
|
||
on: | ||
workflow_call: | ||
inputs: | ||
image: | ||
required: true | ||
type: string | ||
dockerfile: | ||
required: true | ||
type: string | ||
|
||
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v3 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v2 | ||
|
||
- name: Cache Docker layers | ||
uses: actions/cache@v3 | ||
with: | ||
path: /tmp/.buildx-cache | ||
key: ${{ runner.os }}-buildx-${{ github.sha }}-${{ inputs.image }}" | ||
restore-keys: | | ||
${{ runner.os }}-buildx- | ||
- name: Extract metadata (tags, labels) for Docker | ||
id: meta | ||
uses: docker/metadata-action@v4 | ||
with: | ||
images: ${{ inputs.image }} | ||
tags: | | ||
type=ref,event=tag | ||
# set latest tag for default branch | ||
type=raw,value=latest,enable={{is_default_branch}} | ||
- name: Login to GitHub Container Registry | ||
uses: docker/login-action@v2 | ||
with: | ||
registry: ghcr.io | ||
username: ${{ github.repository_owner }} | ||
password: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Build and Push to GitHub Packages | ||
uses: docker/build-push-action@v4 | ||
with: | ||
context: . | ||
file: ${{ inputs.dockerfile }} | ||
push: true | ||
tags: ${{ steps.meta.outputs.tags }} | ||
labels: ${{ steps.meta.outputs.labels }} | ||
cache-from: type=local,src=/tmp/.buildx-cache | ||
cache-to: type=local,dest=/tmp/.buildx-cache |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,180 +1,26 @@ | ||
name: Deploy | ||
name: Deploy to staging | ||
on: | ||
push: | ||
branches: | ||
- "master" | ||
|
||
jobs: | ||
test: | ||
runs-on: ubuntu-latest | ||
services: | ||
memcached: | ||
image: memcached:1.4.31 | ||
ports: | ||
- 11211/udp | ||
mysql: | ||
image: mysql:5.7 | ||
env: | ||
MYSQL_DATABASE: metrics_stage | ||
MYSQL_ALLOW_EMPTY_PASSWORD: "yes" | ||
ports: | ||
- 3306 | ||
redis: | ||
image: redis:6 | ||
ports: | ||
- 6379:6379 | ||
env: | ||
MEMCACHE_SERVERS: "localhost:11211" | ||
MYSQL_HOST: "127.0.0.1" | ||
MYSQL_DATABASE: metrics_stage | ||
MYSQL_USER: root | ||
SECRET_KEY_BASE: ${{ secrets.SECRET_KEY_BASE }} | ||
SESSION_ENCRYPTED_COOKIE_SALT: ${{ secrets.SESSION_ENCRYPTED_COOKIE_SALT }} | ||
JWT_PRIVATE_KEY: ${{ secrets.JWT_PRIVATE_KEY }} | ||
JWT_PUBLIC_KEY: ${{ secrets.JWT_PUBLIC_KEY }} | ||
AWS_REGION: ${{ secrets.AWS_REGION }} | ||
steps: | ||
- uses: actions/checkout@v2 | ||
- name: Set up Ruby 2.6 | ||
uses: actions/setup-ruby@v1 | ||
with: | ||
ruby-version: '2.6.x' | ||
- uses: actions/cache@v2 | ||
with: | ||
path: vendor/bundle | ||
key: ${{ runner.os }}-gems-${{ hashFiles('**/Gemfile.lock') }} | ||
restore-keys: | | ||
${{ runner.os }}-gems- | ||
- name: Install | ||
env: | ||
MYSQL_PORT: ${{ job.services.mysql.ports[3306] }} | ||
run: | | ||
cp .env.build .env | ||
gem install bundler | ||
bundle config path vendor/bundle | ||
bundle install --jobs 4 --retry 3 | ||
sudo /etc/init.d/mysql start | ||
bundle exec rails db:setup RAILS_ENV=test | ||
- name: Lint and Test | ||
env: | ||
MYSQL_PORT: ${{ job.services.mysql.ports[3306] }} | ||
MEMCACHE_SERVERS: "localhost:11211" | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
AWS_S3_BUCKET: 'metrics-api.stage.datacite.org' | ||
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 }} | ||
uses: ./.github/workflows/test.yml | ||
|
||
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: Push to Docker Hub | ||
uses: docker/build-push-action@v2 | ||
with: | ||
context: . | ||
file: ./Dockerfile | ||
push: true | ||
tags: ${{ github.repository }}:latest | ||
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 }}:latest | ||
cache-from: type=local,src=/tmp/.buildx-cache | ||
cache-to: type=local,dest=/tmp/.buildx-cache | ||
uses: ./.github/workflows/build_docker.yml | ||
with: | ||
image: ghcr.io/${{ github.repository }}web | ||
dockerfile: ./Dockerfile | ||
|
||
deploy: | ||
needs: [test, build] | ||
runs-on: ubuntu-latest | ||
env: | ||
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v2 | ||
with: | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
- name: Extract variables | ||
shell: bash | ||
run: | | ||
echo "::set-output name=BRANCH::$(echo ${GITHUB_REF#refs/heads/} | sed 's/\//_/g')" | ||
echo "::set-output name=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)" | ||
echo "::set-output name=MESSAGE::$(git log --format=%B -n 1 ${{ github.event.after }})" | ||
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 stage/services/metrics-api/_sashimi.auto.tfvars.tmpl:stage/services/metrics-api/_sashimi.auto.tfvars | ||
git config --local user.email "[email protected]" | ||
git config --local user.name "GitHub Action" | ||
git add stage/services/metrics-api/_sashimi.auto.tfvars | ||
git commit -m "Adding sashimi git variables for commit ${{ steps.extract_variables.outputs.GIT_SHA }}" | ||
- 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: 'A new version of the <https://api.stage.datacite.org|METRICS API> is been deployed to stage.' | ||
failure_text: '${env.GITHUB_WORKFLOW} (${env.GITHUB_RUN_NUMBER}) build failed' | ||
fields: | | ||
[{ "title": "Commit message", "value": "${{ steps.extract_variables.outputs.MESSAGE }}" }, | ||
{ "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": "Branch", "value": "<https://github.com/${{ github.repository }}/tree/${{ steps.extract_variables.outputs.BRANCH }}|${{ steps.extract_variables.outputs.BRANCH }}>", "short": true }] | ||
uses: ./.github/workflows/deployment.yml | ||
with: | ||
versionvar_filename: sashimi | ||
service_name: metrics-api | ||
env_name: stage | ||
secrets: | ||
PERSONAL_ACCESS_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN }} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
name: Deploy | ||
|
||
on: | ||
workflow_call: | ||
inputs: | ||
versionvar_filename: | ||
required: true | ||
type: string | ||
service_name: | ||
required: true | ||
type: string | ||
env_name: | ||
required: true | ||
type: string | ||
secrets: | ||
PERSONAL_ACCESS_TOKEN: | ||
required: true | ||
|
||
jobs: | ||
|
||
deploy: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v3 | ||
with: | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
|
||
- name: Extract variables | ||
shell: bash | ||
run: | | ||
echo "BRANCH=$(echo ${GITHUB_REF#refs/heads/} | sed 's/\//_/g')" >> $GITHUB_OUTPUT | ||
echo "TAG=$(git tag --points-at HEAD)" >> $GITHUB_OUTPUT | ||
echo "GIT_SHA=$(git rev-parse HEAD)" >> $GITHUB_OUTPUT | ||
echo "GIT_SHA_SHORT=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT | ||
id: extract_variables | ||
|
||
- name: Checkout terraform config repo | ||
uses: actions/checkout@v3 | ||
with: | ||
repository: 'datacite/mastino' | ||
persist-credentials: false | ||
|
||
- name: Commit changes to terraform config repository | ||
run: | | ||
export GIT_SHA=${{ steps.extract_variables.outputs.GIT_SHA_SHORT }} | ||
export GIT_TAG=${{ steps.extract_variables.outputs.TAG }} | ||
export VERSION_FILENAME=${{ inputs.env_name }}/services/${{ inputs.service_name }}/${{ inputs.versionvar_filename }}.auto.tfvars | ||
sed -e "s/{{ .Env.GIT_SHA }}/$GIT_SHA/g" -e "s/{{ .Env.GIT_TAG }}/$GIT_TAG/g" $VERSION_FILENAME.tmpl > $VERSION_FILENAME | ||
git config --local user.email "[email protected]" | ||
git config --local user.name "GitHub Action" | ||
git add $VERSION_FILENAME | ||
git commit -m "Adding ${{ inputs.versionvar_filename }} git variables for commit ${{ steps.extract_variables.outputs.GIT_TAG }}" | ||
- name: Push changes | ||
uses: ad-m/github-push-action@master | ||
with: | ||
github_token: ${{ secrets.PERSONAL_ACCESS_TOKEN }} | ||
repository: 'datacite/mastino' | ||
branch: 'refs/heads/master' | ||
tags: false |
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
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