chore(build-test): Add exit-on-error to build test scripts (#5753) #4988
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
# Description: This workflow runs unit + e2e tests, then publishes UI packages | |
# to `@next` NPM tag. | |
# | |
# Triggered by: merge to `main` | |
name: Test and Publish / next | |
concurrency: | |
group: e2e-${{ github.sha }} | |
cancel-in-progress: true | |
on: | |
push: | |
branches: [main] | |
permissions: | |
id-token: write # This is required for requesting the JWT | |
contents: read # This is required for actions/checkout | |
jobs: | |
setup-cache: | |
uses: aws-amplify/amplify-ui/.github/workflows/reusable-setup-cache.yml@main | |
with: | |
commit: ${{ github.sha }} | |
repository: ${{ github.repository }} | |
unit: | |
uses: aws-amplify/amplify-ui/.github/workflows/reusable-unit.yml@main | |
needs: setup-cache | |
with: | |
commit: ${{ github.sha }} | |
repository: ${{ github.repository }} | |
e2e: | |
uses: aws-amplify/amplify-ui/.github/workflows/reusable-e2e.yml@main | |
needs: unit | |
with: | |
commit: ${{ github.sha }} | |
repository: ${{ github.repository }} | |
skip-changed-packages-check: 'true' # always run e2e tests for native platform on main | |
secrets: | |
AUTH_E2E_ROLE_ARN: ${{ secrets.AUTH_E2E_ROLE_ARN }} | |
DATASTORE_E2E_ROLE_ARN: ${{ secrets.DATASTORE_E2E_ROLE_ARN }} | |
GEO_E2E_ROLE_ARN: ${{ secrets.GEO_E2E_ROLE_ARN }} | |
STORAGE_E2E_ROLE_ARN: ${{ secrets.STORAGE_E2E_ROLE_ARN }} | |
LIVENESS_E2E_ROLE_ARN: ${{ secrets.LIVENESS_E2E_ROLE_ARN }} | |
IN_APP_MESSAGING_E2E_ROLE_ARN: ${{ secrets.IN_APP_MESSAGING_E2E_ROLE_ARN }} | |
DOMAIN: ${{ secrets.DOMAIN }} | |
PHONE_NUMBER: ${{ secrets.PHONE_NUMBER }} | |
USERNAME: ${{ secrets.USERNAME }} | |
NEW_PASSWORD: ${{ secrets.NEW_PASSWORD }} | |
VALID_PASSWORD: ${{ secrets.VALID_PASSWORD }} | |
SITE_URL: ${{ secrets.SITE_URL }} | |
DOCSEARCH_DOCS_APP_ID: ${{ secrets.DOCSEARCH_DOCS_APP_ID }} | |
DOCSEARCH_DOCS_API_KEY: ${{ secrets.DOCSEARCH_DOCS_API_KEY }} | |
DOCSEARCH_DOCS_INDEX_NAME: ${{ secrets.DOCSEARCH_DOCS_INDEX_NAME }} | |
publish: | |
uses: aws-amplify/amplify-ui/.github/workflows/reusable-tagged-publish.yml@main | |
with: | |
dist-tag: next | |
secrets: | |
NPM_TOKEN: ${{ secrets.NPM_TOKEN }} | |
deploy-sample-app: | |
runs-on: ubuntu-latest | |
environment: deployment | |
needs: publish | |
steps: | |
- name: Trigger build for beta liveness sample app pointing at next tag | |
run: curl -X POST -d {} $ENDPOINT -H "Content-Type:application/json" | |
env: | |
ENDPOINT: ${{ secrets.LIVENESS_BETA_SAMPLE_APP_BUILD_TRIGGER }} | |
build-test-v2: | |
uses: ./.github/workflows/reusable-build-system-test.yml | |
needs: publish | |
with: | |
dist-tag: next | |
build-test-v2-react-native: | |
uses: ./.github/workflows/reusable-build-system-test-react-native.yml | |
needs: publish | |
with: | |
dist-tag: next | |
build-test: | |
needs: publish | |
runs-on: ubuntu-latest | |
environment: ci | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@b80ff79f1755d06ba70441c368a6fe801f5f3a62 # v4.1.3 https://github.com/actions/checkout/commit/cd7d8d697e10461458bc61a30d094dc601a8b017 | |
- name: Setup Node.js 20 | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2 https://github.com/actions/setup-node/commit/60edb5dd545a775178f52524783378180af0d1f8 | |
with: | |
node-version: 20 | |
cache: 'yarn' | |
env: | |
SEGMENT_DOWNLOAD_TIMEOUT_MINS: 2 | |
- name: Add Amplify CLI | |
run: yarn global add @aws-amplify/cli | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@e3dd6a429d7300a6a4c196c26e071d42e0343502 # v4.0.2 https://github.com/aws-actions/configure-aws-credentials/commit/e3dd6a429d7300a6a4c196c26e071d42e0343502 | |
with: | |
aws-region: us-east-2 | |
role-to-assume: ${{ secrets.AUTH_E2E_ROLE_ARN }} | |
# Amplify CLI does not support headless pull with temporary credentials | |
# when useProfile is false. | |
# See: https://github.com/aws-amplify/amplify-cli/issues/11009. | |
- name: Create temp AWS profile | |
run: | | |
aws configure set aws_access_key_id $AWS_ACCESS_KEY_ID && \ | |
aws configure set aws_secret_access_key $AWS_SECRET_ACCESS_KEY && \ | |
aws configure set aws_session_token $AWS_SESSION_TOKEN && \ | |
aws configure set default.region $AWS_REGION | |
- name: Pull down AWS environments | |
run: yarn pull | |
working-directory: ./canary | |
- name: Delete AWS Profile | |
run: rm -rf ~/.aws | |
- name: Setup canary apps against @next | |
run: yarn setup:next | |
working-directory: ./canary | |
- name: Run yarn install on each sample app | |
run: yarn install | |
working-directory: ./canary | |
- name: Run yarn build on each sample app | |
run: yarn build | |
working-directory: ./canary | |
log-failure-metric: | |
# Send a failure data point to metric PublishNextFailure in github-workflows@ us-east-2, if it's a failure | |
runs-on: ubuntu-latest | |
environment: ci | |
needs: | |
- build-test | |
- build-test-v2 | |
- build-test-v2-react-native | |
if: ${{ failure() }} | |
steps: | |
- name: Log failure data point to metric PublishNextFailure | |
uses: aws-amplify/amplify-ui/.github/actions/log-metric@main | |
with: | |
metric-name: PublishNextFailure | |
value: 1 | |
role-to-assume: ${{ secrets.METRIC_LOGGER_ROLE_ARN }} | |
aws-region: us-east-2 | |
log-success-metric: | |
# Send a success data point to metric PublishNextFailure in github-workflows@ us-east-2, if it's a success | |
runs-on: ubuntu-latest | |
environment: ci | |
needs: | |
- build-test | |
- build-test-v2 | |
- build-test-v2-react-native | |
if: ${{ success() }} | |
steps: | |
- name: Log success data point to metric PublishNextFailure | |
uses: aws-amplify/amplify-ui/.github/actions/log-metric@main | |
with: | |
metric-name: PublishNextFailure | |
value: 0 | |
role-to-assume: ${{ secrets.METRIC_LOGGER_ROLE_ARN }} | |
aws-region: us-east-2 |