Merge remote-tracking branch 'upstream/next' into next #1
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: Deploy DEV WS | |
# Controls when the action will run. Triggers the workflow on push or pull request | |
# events but only for the master branch | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- next | |
- main | |
paths: | |
- 'apps/ws/**' | |
env: | |
TF_WORKSPACE: novu-dev | |
jobs: | |
test_ws: | |
strategy: | |
matrix: | |
name: ['novu/ws-ee', 'novu/ws'] | |
uses: ./.github/workflows/reusable-ws-e2e.yml | |
with: | |
ee: ${{ contains (matrix.name,'-ee') }} | |
secrets: inherit | |
# This workflow contains a single job called "build" | |
deploy_ws: | |
# The type of runner that the job will run on | |
runs-on: ubuntu-latest | |
needs: test_ws | |
timeout-minutes: 80 | |
environment: Development | |
if: "!contains(github.event.head_commit.message, 'ci skip')" | |
strategy: | |
matrix: | |
name: ['novu/ws-ee'] | |
# Steps represent a sequence of tasks that will be executed as part of the job | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: ${{ contains (matrix.name,'-ee') }} | |
token: ${{ secrets.SUBMODULES_TOKEN }} | |
- uses: ./.github/actions/setup-project | |
with: | |
submodules: ${{ contains (matrix.name,'-ee') }} | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: eu-west-2 | |
- name: Checkout cloud infra | |
uses: actions/checkout@master | |
with: | |
repository: novuhq/cloud-infra | |
token: ${{ secrets.GH_PACKAGES }} | |
path: cloud-infra | |
- name: Terraform setup | |
uses: hashicorp/setup-terraform@v1 | |
with: | |
cli_config_credentials_token: ${{ secrets.TF_API_TOKEN }} | |
terraform_version: 1.5.5 | |
terraform_wrapper: false | |
- name: Terraform Init | |
working-directory: cloud-infra/terraform/novu/aws | |
run: terraform init | |
- name: Terraform get output | |
working-directory: cloud-infra/terraform/novu/aws | |
id: terraform | |
run: | | |
echo "ws_ecs_container_name=$(terraform output -json ws_ecs_container_name | jq -r .)" >> $GITHUB_ENV | |
echo "ws_ecs_service=$(terraform output -json ws_ecs_service | jq -r .)" >> $GITHUB_ENV | |
echo "ws_ecs_cluster=$(terraform output -json ws_ecs_cluster | jq -r .)" >> $GITHUB_ENV | |
echo "ws_task_name=$(terraform output -json ws_task_name | jq -r .)" >> $GITHUB_ENV | |
- name: Download task definition | |
run: | | |
aws ecs describe-task-definition --task-definition ${{ env.ws_task_name }} \ | |
--query taskDefinition > task-definition.json | |
- name: Set Bull MQ Env variable for EE | |
shell: bash | |
run: | | |
echo "BULL_MQ_PRO_NPM_TOKEN=${{ secrets.BULL_MQ_PRO_NPM_TOKEN }}" >> $GITHUB_ENV | |
if: ${{contains(matrix.name, 'ee')}} | |
- name: Build, tag, and push image to Amazon ECR | |
id: build-image | |
env: | |
REGISTRY_OWNER: novuhq | |
DOCKER_NAME: ${{ matrix.name }} | |
IMAGE_TAG: ${{ github.sha }} | |
GH_ACTOR: ${{ github.actor }} | |
GH_PASSWORD: ${{ secrets.GH_PACKAGES }} | |
run: | | |
echo $GH_PASSWORD | docker login ghcr.io -u $GH_ACTOR --password-stdin | |
docker build -t ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:$IMAGE_TAG --build-arg BULL_MQ_PRO_TOKEN=${BULL_MQ_PRO_NPM_TOKEN} -f apps/ws/Dockerfile . | |
docker run --network=host --name api -dit --env NODE_ENV=test ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:$IMAGE_TAG | |
docker run --network=host appropriate/curl --retry 10 --retry-delay 5 --retry-connrefused http://127.0.0.1:1340/v1/health-check | grep 'ok' | |
docker tag ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:$IMAGE_TAG ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:dev | |
docker push ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:dev | |
docker push ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:$IMAGE_TAG | |
echo "IMAGE=ghcr.io/$REGISTRY_OWNER/$DOCKER_NAME:$IMAGE_TAG" >> $GITHUB_OUTPUT | |
- name: Render Amazon ECS task definition | |
id: render-container | |
uses: aws-actions/amazon-ecs-render-task-definition@v1 | |
with: | |
task-definition: task-definition.json | |
container-name: ${{ env.ws_ecs_container_name }} | |
image: ${{ steps.build-image.outputs.IMAGE }} | |
- name: Deploy to Amazon ECS service | |
if: ${{contains(matrix.name, 'ee')}} | |
uses: aws-actions/amazon-ecs-deploy-task-definition@v1 | |
with: | |
task-definition: ${{ steps.render-container.outputs.task-definition }} | |
service: ${{ env.ws_ecs_service }} | |
cluster: ${{ env.ws_ecs_cluster }} | |
wait-for-service-stability: true |