-
Notifications
You must be signed in to change notification settings - Fork 0
61 lines (48 loc) · 1.77 KB
/
cd.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
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 }}
AWS_ACCOUNT: ${{ vars.AWS_ACCOUNT }}
PORT: ${{ vars.PORT }}
PROJECT_NAME: ${{ vars.PROJECT_NAME }}
TABLE_NAME: ${{ vars.TABLE_NAME }}
AWS_FARGATE_CONTAINER_CPU: ${{ vars.AWS_FARGATE_CONTAINER_CPU }}
AWS_FARGATE_CONTAINER_MEMORY: ${{ vars.AWS_FARGATE_CONTAINER_MEMORY }}
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 }}."