Add ci/cd pipeline #1
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: CD pipeline | |
on: | |
pull_request: | |
branches: | |
- main | |
types: [closed] | |
jobs: | |
build: | |
if: github.event.pull_request.merged == true | |
runs-on: ubuntu-latest | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
AWS_REGION: ${{ secrets.AWS_REGION }} | |
steps: | |
- name: Notify Trigger | |
run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event on branch ${{ github.ref }}." | |
- name: Checkout Repository | |
uses: actions/checkout@v2 | |
- name: Setup Node.js | |
uses: actions/setup-node@v2 | |
- name: Cache Dependencies | |
uses: actions/cache@v2 | |
id: backend-npm-cache | |
with: | |
path: "node_modules" | |
key: client-npm-${{ hashFiles('package.json') }} | |
- name: Install Dependencies | |
run: npm install | |
if: steps.backend-npm-cache.outputs.cache-hit != 'true' | |
- name: Configure AWS CLI | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }} | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Build AWS CDK stack | |
run: npm run build | |
- name: Deploy AWS CDK stack | |
run: npx cdk deploy --ci --require-approval never | |
- name: Display Job Status | |
run: echo "🍏 This job's status is ${{ job.status }}." |