Skip to content

Add a command to blow everything up #239

Add a command to blow everything up

Add a command to blow everything up #239

name: Build
on:
pull_request: {}
push:
branches:
- main
tags:
- v*
issue_comment:
types: [created, edited]
jobs:
decide-parameters:
runs-on: ubuntu-latest
steps:
- name: Output environment
run: |
echo '${{ github.ref }}'
echo <<-EOF
${{ toJSON(github.event) }}
EOF
outputs:
# Run builds for all non-comment triggers.
should-build: >-
${{
github.event_name != 'issue_comment'
}}
# Run tests for all non-comment triggers;
# ignore non-PR comment triggers;
# and for PR comment triggers, only run tests if they are explicitly
# requested.
should-test: >-
${{
github.event_name != 'issue_comment' ||
(
github.event.issue.pull_request && (
contains(github.event.comment.body, 'rerun tests, please') ||
contains(github.event.comment.body, 'Rerun tests, please')
)
)
}}
# Deploy for all main merges;
# for non-main meges, deploy for all tags;
# for comments, only deploy if explicitly requested;
# and for PR comment triggers, only run deployments if they are
# explicitly requested.
should-deploy: >-
${{
github.ref == 'refs/heads/main' ||
startsWith(github.ref, 'refs/tags/') ||
(
github.event_name == 'issue_comment' &&
github.event.issue.pull_request && (
contains(github.event.comment.body, 'deploy, please') ||
contains(github.event.comment.body, 'Deploy, please')
)
)
}}
output-parameters:
needs: decide-parameters
runs-on: ubuntu-latest
steps:
- name: Output parameters
run: |
echo '${{ toJSON(needs.decide-parameters.outputs) }}'
test:
runs-on: ubuntu-latest
needs: decide-parameters
if: ${{ needs.decide-parameters.outputs.should-test == 'true' }}
steps:
- uses: actions/checkout@v3
- name: Read .nvmrc
run: echo "NVMRC=$(cat ./.nvmrc)" > $GITHUB_OUTPUT
id: nvm
- name: Use Node + Yarn
uses: actions/setup-node@v3
with:
node-version: "${{ steps.nvm.outputs.NVMRC }}"
cache: "yarn"
- run: yarn install --frozen-lockfile
- run: yarn test
build-and-push-image:
runs-on: ubuntu-latest
needs: [test, decide-parameters]
if: ${{ needs.decide-parameters.outputs.should-build == 'true' || needs.decide-parameters.outputs.should-deploy == 'true' }}
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Read .nvmrc
run: echo "NVMRC=$(cat ./.nvmrc)" > $GITHUB_OUTPUT
id: nvm
- name: Use Node + Yarn
uses: actions/setup-node@v3
with:
node-version: "${{ steps.nvm.outputs.NVMRC }}"
cache: "yarn"
- run: yarn install --frozen-lockfile
- name: Build docker image
run: |
echo $GITHUB_SHA > BUILD
docker build . -f infrastructure/docker/Dockerfile -t gcr.io/thesis-ops-2748/valkyrie:$GITHUB_SHA
- name: Authenticate push with GCP
if: ${{ needs.decide-parameters.outputs.should-deploy == 'true' }}
id: 'auth-push'
uses: 'google-github-actions/auth@v0'
with:
credentials_json: '${{ secrets.GCP_GCR_CREDENTIALS }}'
- name: Set up GCP tools
if: ${{ needs.decide-parameters.outputs.should-deploy == 'true' }}
uses: google-github-actions/setup-gcloud@v0
- name: Push docker image to GCP
if: ${{ needs.decide-parameters.outputs.should-deploy == 'true' }}
run: |
# Set up docker to authenticate via gcloud command-line tool.
gcloud auth configure-docker
docker push gcr.io/thesis-ops-2748/valkyrie:${{ github.sha }}
deploy:
needs: [build-and-push-image, decide-parameters]
if: ${{ needs.decide-parameters.outputs.should-deploy == 'true' }}
uses: ./.github/workflows/deploy.yml
with:
docker-image-name: valkyrie
docker-image-version: ${{ github.sha }}
gcp-project-name: thesis-ops
gcp-project-id: thesis-ops-2748
secrets:
GCP_DEPLOY_CREDENTIALS: ${{ secrets.GCP_DEPLOY_CREDENTIALS }}
lint:
needs: [decide-parameters]
if: ${{ needs.decide-parameters.outputs.should-build == 'true' }}
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Read .nvmrc
run: echo "NVMRC=$(cat ./.nvmrc)" > $GITHUB_OUTPUT
id: nvm
- name: Use Node + Yarn
uses: actions/setup-node@v3
with:
node-version: "${{ steps.nvm.outputs.NVMRC }}"
cache: "yarn"
- run: yarn install --frozen-lockfile
- run: yarn lint