refactor: refactor network picker #59443
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: Main | |
on: | |
push: | |
branches: | |
- main | |
- master | |
- Version-v* | |
- trigger-ci* | |
pull_request: | |
types: | |
- opened | |
- reopened | |
- synchronize | |
merge_group: | |
jobs: | |
lint-workflows: | |
name: Lint workflows | |
uses: metamask/github-tools/.github/workflows/lint-workflows.yml@1d657e262aea7e3f216754febb624831527d2565 | |
test-lint-shellcheck: | |
name: Test lint shellcheck | |
uses: ./.github/workflows/test-lint-shellcheck.yml | |
test-lint: | |
name: Test lint | |
uses: ./.github/workflows/test-lint.yml | |
test-circular-deps: | |
name: Test circular deps | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Setup environment | |
uses: metamask/github-tools/.github/actions/setup-environment@1d657e262aea7e3f216754febb624831527d2565 | |
- name: Check circular dependencies | |
run: yarn circular-deps:check | |
test-lint-changelog: | |
name: Test lint changelog | |
uses: ./.github/workflows/test-lint-changelog.yml | |
test-lint-lockfile: | |
name: Test lint lockfile | |
uses: ./.github/workflows/test-lint-lockfile.yml | |
test-deps-audit: | |
name: Test deps audit | |
uses: ./.github/workflows/test-deps-audit.yml | |
test-yarn-dedupe: | |
name: Test yarn dedupe | |
uses: ./.github/workflows/test-yarn-dedupe.yml | |
test-deps-depcheck: | |
name: Test deps depcheck | |
uses: ./.github/workflows/test-deps-depcheck.yml | |
test-storybook: | |
name: Test storybook | |
uses: ./.github/workflows/test-storybook.yml | |
validate-lavamoat-allow-scripts: | |
name: Validate lavamoat allow scripts | |
uses: ./.github/workflows/validate-lavamoat-allow-scripts.yml | |
validate-lavamoat-policy-build: | |
name: Validate lavamoat policy build | |
uses: ./.github/workflows/validate-lavamoat-policy-build.yml | |
validate-lavamoat-policy-webapp: | |
name: Validate lavamoat policy webapp | |
uses: ./.github/workflows/validate-lavamoat-policy-webapp.yml | |
prep-build-test-browserify: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Setup environment | |
uses: metamask/github-tools/.github/actions/setup-environment@1d657e262aea7e3f216754febb624831527d2565 | |
- run: yarn build:test | |
- name: Upload artifact prep-build-test-browserify | |
uses: actions/upload-artifact@v4 | |
with: | |
name: prep-build-test-browserify | |
path: ./dist/ | |
prep-build-test-webpack: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Setup environment | |
uses: metamask/github-tools/.github/actions/setup-environment@1d657e262aea7e3f216754febb624831527d2565 | |
- run: yarn webpack --test --no-lavamoat --no-cache --browser=chrome --lockdown --sentry --snow --env production | |
env: | |
SEGMENT_PROD_WRITE_KEY: '-' # A fake key just to make the build succeed | |
- name: Upload artifact prep-build-test-webpack | |
uses: actions/upload-artifact@v4 | |
with: | |
name: prep-build-test-webpack | |
path: ./dist/ | |
run-tests: | |
name: Run tests | |
uses: ./.github/workflows/run-tests.yml | |
run-benchmarks: | |
uses: ./.github/workflows/run-benchmarks.yml | |
needs: | |
- prep-build-test-browserify | |
- prep-build-test-webpack | |
wait-for-circleci-workflow-status: | |
name: Wait for CircleCI workflow status | |
uses: ./.github/workflows/wait-for-circleci-workflow-status.yml | |
runway: | |
name: Runway | |
# For a `pull_request` event, the branch is `github.head_ref``. | |
# For a `push` event, the branch is `github.ref_name`. | |
if: ${{ startsWith(github.head_ref || github.ref_name, 'Version-v') }} | |
needs: | |
- wait-for-circleci-workflow-status | |
uses: ./.github/workflows/runway.yml | |
build-storybook: | |
name: Build storybook | |
uses: ./.github/workflows/build-storybook.yml | |
secrets: | |
STORYBOOK_TOKEN: ${{ secrets.STORYBOOK_TOKEN }} | |
permissions: | |
contents: read | |
# id-token permission is required for uploading to s3 | |
id-token: write | |
build-beta: | |
name: Build beta | |
uses: ./.github/workflows/build-beta.yml | |
permissions: | |
contents: read | |
# id-token permission is required for uploading to s3 | |
id-token: write | |
publish-prerelease: | |
name: Publish prerelease | |
if: ${{ github.event_name == 'pull_request' }} | |
needs: | |
- wait-for-circleci-workflow-status | |
- build-storybook | |
- build-beta | |
uses: ./.github/workflows/publish-prerelease.yml | |
secrets: | |
PR_COMMENT_TOKEN: ${{ secrets.PR_COMMENT_TOKEN }} | |
# Explanation for all-jobs-completed and all-jobs-pass being separate: | |
# https://github.com/MetaMask/metamask-module-template/pull/151 | |
all-jobs-completed: | |
name: All jobs completed | |
runs-on: ubuntu-latest | |
needs: | |
- lint-workflows | |
- test-lint-shellcheck | |
- test-lint | |
- test-lint-changelog | |
- test-lint-lockfile | |
- test-yarn-dedupe | |
- test-deps-depcheck | |
- test-storybook | |
- validate-lavamoat-allow-scripts | |
- validate-lavamoat-policy-build | |
- validate-lavamoat-policy-webapp | |
- run-tests | |
- wait-for-circleci-workflow-status | |
- build-storybook | |
- build-beta | |
outputs: | |
PASSED: ${{ steps.set-output.outputs.PASSED }} | |
steps: | |
- name: Set PASSED output | |
id: set-output | |
run: echo "PASSED=true" >> "$GITHUB_OUTPUT" | |
all-jobs-pass: | |
name: All jobs pass | |
if: ${{ always() }} | |
runs-on: ubuntu-latest | |
needs: | |
- all-jobs-completed | |
steps: | |
- name: Check that all jobs have passed | |
run: | | |
passed="${{ needs.all-jobs-completed.outputs.PASSED }}" | |
if [[ $passed != "true" ]]; then | |
exit 1 | |
fi | |
log-merge-group-failure: | |
name: Log merge group failure | |
# Only run this job if the merge group event fails, skip on forks | |
if: ${{ github.event_name == 'merge_group' && failure() && !github.event.repository.fork }} | |
needs: | |
- all-jobs-pass | |
uses: metamask/github-tools/.github/workflows/log-merge-group-failure.yml@6bbad335a01fce1a9ec1eabd9515542c225d46c0 | |
secrets: | |
GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.GOOGLE_APPLICATION_CREDENTIALS }} | |
GOOGLE_SERVICE_ACCOUNT: ${{ secrets.GOOGLE_SERVICE_ACCOUNT }} | |
SPREADSHEET_ID: ${{ secrets.GOOGLE_MERGE_QUEUE_SPREADSHEET_ID }} | |
SHEET_NAME: ${{ secrets.GOOGLE_MERGE_QUEUE_SHEET_NAME }} |