Skip to content

feat: add support for NextJS in SST & remove CJS support #1173

feat: add support for NextJS in SST & remove CJS support

feat: add support for NextJS in SST & remove CJS support #1173

Workflow file for this run

name: build
on:
pull_request: {}
workflow_call: {}
jobs:
unit-tests:
runs-on: ubuntu-latest
env:
CI: "true"
CLEAN_UP_STACK: "1"
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/build
- name: Run tests
run: pnpm test
deploy-runtime:
concurrency: pr-test-runtime
runs-on: ubuntu-latest
permissions:
contents: write
id-token: write
env:
CI: "true"
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/build
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: arn:aws:iam::593491530938:role/githubActionStack-githubactionroleA106E4DC-14SHKLVA61IN4
aws-region: us-east-1
role-duration-seconds: 3600
- name: Deploy Runtime Tests
run: pnpm -r --filter tests-runtime run deploy:runtime
env:
EVENTUAL_LOCAL: "1"
- name: Upload deployment output as artifact
uses: actions/upload-artifact@v3
with:
name: deployment-output
path: ./apps/tests/aws-runtime/cdk.out/outputs.json
test-runtime:
needs: [deploy-runtime]
concurrency: pr-test-runtime
runs-on: ubuntu-latest
permissions:
contents: write
id-token: write
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/build
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: arn:aws:iam::593491530938:role/githubActionStack-githubactionroleA106E4DC-14SHKLVA61IN4
aws-region: us-east-1
role-duration-seconds: 3600
- name: Download artifact with variable
id: deployment-output
uses: actions/download-artifact@v3
with:
name: deployment-output
path: deployment
- run: |
echo "TEST_ROLE_ARN=$(node -p 'JSON.parse(require("fs").readFileSync("${{ steps.deployment-output.outputs.download-path }}/outputs.json"))["eventual-tests"].roleArn')" >> $GITHUB_ENV
- name: Configure Test Role Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: ${{ env.TEST_ROLE_ARN }}
aws-region: us-east-1
role-duration-seconds: 3600
aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }}
aws-session-token: ${{ env.AWS_SESSION_TOKEN }}
role-skip-session-tagging: true
role-session-name: ${{ github.job }}
- name: Run Runtime Tests
run: pnpm -r --filter tests-runtime run test:runtime
env:
OUTPUTS_FILE: "${{ steps.deployment-output.outputs.download-path }}/outputs.json"
test-local:
needs: [deploy-runtime]
runs-on: ubuntu-latest
permissions:
contents: write
id-token: write
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/build
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: arn:aws:iam::593491530938:role/githubActionStack-githubactionroleA106E4DC-14SHKLVA61IN4
aws-region: us-east-1
role-duration-seconds: 3600
- name: Download artifact with variable
id: deployment-output
uses: actions/download-artifact@v3
with:
name: deployment-output
path: deployment
- run: |
echo "TEST_ROLE_ARN=$(node -p 'JSON.parse(require("fs").readFileSync("${{ steps.deployment-output.outputs.download-path }}/outputs.json"))["eventual-tests"].roleArn')" >> $GITHUB_ENV
- name: Configure Test Role Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: ${{ env.TEST_ROLE_ARN }}
aws-region: us-east-1
role-duration-seconds: 3600
aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }}
aws-session-token: ${{ env.AWS_SESSION_TOKEN }}
role-skip-session-tagging: true
role-session-name: ${{ github.job }}
- name: Run Local Tests
run: pnpm -r --filter tests-runtime run test:local-start
test-cli:
needs: [test-runtime]
runs-on: ubuntu-latest
env:
CI: "true"
permissions:
contents: write
id-token: write
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/build
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: arn:aws:iam::593491530938:role/githubActionStack-githubactionroleA106E4DC-14SHKLVA61IN4
aws-region: us-east-1
role-duration-seconds: 3600
- name: Download artifact with variable
id: deployment-output
uses: actions/download-artifact@v3
with:
name: deployment-output
path: deployment
- run: |
echo "TEST_ROLE_ARN=$(node -p 'JSON.parse(require("fs").readFileSync("${{ steps.deployment-output.outputs.download-path }}/outputs.json"))["eventual-tests"].roleArn')" >> $GITHUB_ENV
- name: Configure Test Role Credentials
uses: aws-actions/configure-aws-credentials@v3-node20
with:
role-to-assume: ${{ env.TEST_ROLE_ARN }}
aws-region: us-east-1
role-duration-seconds: 3600
aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }}
aws-session-token: ${{ env.AWS_SESSION_TOKEN }}
role-skip-session-tagging: true
role-session-name: ${{ github.job }}
- name: Run CLI Tests
run: pnpm -r --filter tests-runtime run test:cli
test-create:
runs-on: ubuntu-latest
permissions:
contents: write
id-token: write
env:
CI: "true"
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/build
- name: Run Create Tests
run: pnpm -r --filter tests-runtime run test:create