feat: add support for NextJS in SST & remove CJS support #1173
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: 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 |