Reverting docker file, removing yarn berry #122
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: Push Image Workflow | |
on: | |
create: | |
push: | |
branches: | |
- release/** | |
- develop | |
- fix-docker-image | |
paths-ignore: | |
- '*.md' | |
env: | |
AWS_REGION: eu-west-2 | |
jobs: | |
test: | |
name: Build Feature | |
# Need to check here as create event can't be filtered by branch name... | |
if: github.ref == 'refs/heads/fix-docker-image' || startsWith(github.ref, 'refs/heads/release') | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@master | |
- name: Generate .env files | |
run: cp .env.example .env | |
- name: Read .nvmrc | |
id: nvm | |
run: echo "name=NVMRC::$(cat .nvmrc)" >> $GITHUB_OUTPUT | |
- name: Setup node | |
uses: actions/setup-node@master | |
with: | |
node-version: '${{ steps.nvm.outputs.NVMRC }}' | |
cache: 'yarn' | |
- name: Install dependencies | |
run: yarn install --immutable | |
- name: Build application | |
run: yarn build | |
- name: Units Tests | |
run: yarn jest --ci | |
build: | |
runs-on: ubuntu-latest | |
outputs: | |
docker-image-name: ${{ steps.docker-image-name.outputs.name }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
# Fetch all commits since we use the total commit count to determine the build version | |
fetch-depth: 0 | |
- name: Setup AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1-node16 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Login to AWS ECR | |
id: login-ecr | |
uses: aws-actions/amazon-ecr-login@v2 | |
- name: Determine & set BUILD_VERSION | |
run: | | |
GIT_COUNT=$(git rev-list $GITHUB_SHA --count) | |
echo "BUILD_VERSION=b_$GIT_COUNT" >> $GITHUB_ENV | |
echo BUILD_VERSION is ${{ env.BUILD_VERSION }} | |
- name: Build Docker image | |
env: | |
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} | |
run: docker build -t $ECR_REGISTRY/find-a-grant-api:${{ env.BUILD_VERSION }} . | |
- name: Generate Docker image name | |
id: docker-image-name | |
run: | | |
NAME=${{ (github.ref == 'refs/heads/fix-docker-image' && 'find-api-dev-image') || (startsWith(github.ref, 'refs/heads/release') && 'find-api-qa-image') }} | |
echo "name=$NAME" >> $GITHUB_OUTPUT | |
- name: Save Docker image | |
env: | |
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} | |
run: docker save --output ${{ steps.docker-image-name.outputs.name }}.tar $ECR_REGISTRY/find-a-grant-api:${{ env.BUILD_VERSION }} | |
- name: Upload Docker image | |
uses: actions/upload-artifact@v3 | |
with: | |
name: ${{ steps.docker-image-name.outputs.name }} | |
path: ${{ steps.docker-image-name.outputs.name }}.tar | |
retention-days: 1 | |
deploy: | |
runs-on: ubuntu-latest | |
environment: AWS | |
needs: [build, test] | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
# Fetch all commits since we use the total commit count to determine the build version | |
fetch-depth: 0 | |
- name: Setup AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1-node16 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Login to AWS ECR | |
id: login-ecr | |
uses: aws-actions/amazon-ecr-login@v2 | |
- name: Determine & set BUILD_VERSION | |
run: | | |
GIT_COUNT=$(git rev-list $GITHUB_SHA --count) | |
echo "BUILD_VERSION=b_$GIT_COUNT" >> $GITHUB_ENV | |
echo BUILD_VERSION is ${{ env.BUILD_VERSION }} | |
- name: Download Docker image | |
uses: actions/download-artifact@v3 | |
with: | |
name: ${{ needs.build.outputs.docker-image-name }} | |
- name: Load Docker image | |
run: docker load --input ${{ needs.build.outputs.docker-image-name }}.tar | |
- name: Push Docker image to AWS ECR | |
env: | |
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} | |
run: docker push $ECR_REGISTRY/find-a-grant-api:${{ env.BUILD_VERSION }} | |
- name: Create env tag | |
env: | |
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} | |
run: | | |
ENV_TAG=${{ (github.ref == 'refs/heads/fix-docker-image' && 'dev') || (startsWith(github.ref, 'refs/heads/release') && 'test') }} | |
docker tag $ECR_REGISTRY/find-a-grant-api:${{ env.BUILD_VERSION }} $ECR_REGISTRY/find-a-grant-api:$ENV_TAG | |
docker push $ECR_REGISTRY/find-a-grant-api:$ENV_TAG | |
- name: Create release tag - if we are committing to a release branch | |
if: ${{ startsWith(github.ref, 'refs/heads/release/') }} | |
env: | |
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} | |
run: | | |
RELEASE_VERSION=V_${GITHUB_REF##*/} | |
docker tag $ECR_REGISTRY/find-a-grant-api:${{ env.BUILD_VERSION }} $ECR_REGISTRY/find-a-grant-api:$RELEASE_VERSION | |
docker push $ECR_REGISTRY/find-a-grant-api:$RELEASE_VERSION |