From 75f02093c7e48cc1e133bd6a3cfbe5a9d55a8112 Mon Sep 17 00:00:00 2001 From: Vitali Zaidman Date: Mon, 5 Aug 2024 14:18:38 +0100 Subject: [PATCH] adding the deploy step --- .circleci/config.yml | 139 ------------------ .circleci/scripts/install_codecov.sh | 16 -- {.circleci => .github}/scripts/publish.sh | 10 +- ...and-test.yml => build-test-and-deploy.yml} | 38 ++++- 4 files changed, 42 insertions(+), 161 deletions(-) delete mode 100644 .circleci/config.yml delete mode 100755 .circleci/scripts/install_codecov.sh rename {.circleci => .github}/scripts/publish.sh (67%) rename .github/workflows/{build-and-test.yml => build-test-and-deploy.yml} (53%) diff --git a/.circleci/config.yml b/.circleci/config.yml deleted file mode 100644 index 102de20ed0..0000000000 --- a/.circleci/config.yml +++ /dev/null @@ -1,139 +0,0 @@ -# CircleCI configuration -# https://circleci.com/docs/configuration-reference/ - -version: 2.1 - -orbs: - win: circleci/windows@2.4.0 - -references: - # For stability, Node.js versions we run against in CI are defined explicitly - # (the "lts" alias may bring in a future version before we support it) - node_supported_lts_versions: &node_supported_lts_versions - - &node_min_supported_version "18.12" - - "20.2" - node_lts_image: &node_lts_image cimg/node:18.12 - - secure_unset_publish_token: &secure_unset_publish_token - environment: - NPM_TOKEN: "" - -commands: - yarn_install: - description: "A wrapper to yarn install with caching" - parameters: - working_directory: - type: string - default: "" - steps: - - restore_cache: - keys: - - dependencies-{{ .Branch }}-{{ checksum "yarn.lock" }} - - dependencies-{{ .Branch }}- - - run: - name: Installing dependencies - command: yarn --frozen-lockfile --non-interactive --ignore-scripts - working_directory: << parameters.working_directory >> - - save_cache: - paths: - - node_modules - key: dependencies-{{ .Branch }}-{{ checksum "yarn.lock" }} - - install_and_run_tests: - description: | - Install dependencies and run tests (common steps for test- jobs) - steps: - - yarn_install - - run: yarn jest --ci --maxWorkers 4 --reporters=default --reporters=jest-junit - - store_test_results: - path: ./reports/ - -jobs: - run-js-checks: - <<: *secure_unset_publish_token - docker: - - image: *node_lts_image - steps: - - checkout - - yarn_install - - run: yarn typecheck - - run: yarn typecheck-ts - - run: yarn lint - - run: yarn test-smoke - - test-with-coverage: - <<: *secure_unset_publish_token - docker: - - image: *node_lts_image - steps: - - checkout - - yarn_install - - run: yarn test-coverage - - run: - name: Download Codecov Uploader - command: ./.circleci/scripts/install_codecov.sh - - run: - name: Upload coverage results - command: ./codecov -t ${CODECOV_TOKEN} -f ./coverage/coverage-final.json - - test: - <<: *secure_unset_publish_token - parameters: - node-version: - type: string - docker: - - image: cimg/node:<< parameters.node-version >> - steps: - - checkout - - install_and_run_tests - - test-windows: - <<: *secure_unset_publish_token - parameters: - node-version: - type: string - executor: - name: win/default - steps: - - checkout - - run: - name: Install Node.js and Yarn - command: | - choco install -y nodejs --version << parameters.node-version >> - choco install -y yarn - - install_and_run_tests - - publish-to-npm: - docker: - - image: *node_lts_image - steps: - - checkout - - yarn_install - - run: echo "//registry.npmjs.org/:_authToken=$NPM_TOKEN" >> ~/.npmrc - - run: - name: Infer dist-tag and run npm run publish - command: ./.circleci/scripts/publish.sh - - run: rm ~/.npmrc - -workflows: - build-and-deploy: - jobs: - - run-js-checks - - test-with-coverage - - test: - matrix: - parameters: - node-version: *node_supported_lts_versions - - test-windows: - matrix: - parameters: - node-version: [*node_min_supported_version] - filters: - branches: - only: /windows\/.*/ - - publish-to-npm: - filters: - branches: - ignore: /.*/ - tags: - only: /v\d+(\.\d+){2}(-.*)?/ diff --git a/.circleci/scripts/install_codecov.sh b/.circleci/scripts/install_codecov.sh deleted file mode 100755 index 13b8e631d8..0000000000 --- a/.circleci/scripts/install_codecov.sh +++ /dev/null @@ -1,16 +0,0 @@ -#!/bin/sh - -# Install Codecov Uploader -# See https://docs.codecov.com/docs/codecov-uploader#using-the-uploader-with-codecovio-cloud - -CODECOV_URL="https://uploader.codecov.io" - -curl "${CODECOV_URL}/verification.gpg" | gpg --no-default-keyring --keyring trustedkeys.gpg --import -curl -Os "${CODECOV_URL}/latest/linux/codecov" -curl -Os "${CODECOV_URL}/latest/linux/codecov.SHA256SUM" -curl -Os "${CODECOV_URL}/latest/linux/codecov.SHA256SUM.sig" - -gpgv codecov.SHA256SUM.sig codecov.SHA256SUM -shasum -a 256 -c codecov.SHA256SUM - -chmod +x codecov diff --git a/.circleci/scripts/publish.sh b/.github/scripts/publish.sh similarity index 67% rename from .circleci/scripts/publish.sh rename to .github/scripts/publish.sh index 2c895c3255..d776b29b9b 100755 --- a/.circleci/scripts/publish.sh +++ b/.github/scripts/publish.sh @@ -4,15 +4,17 @@ # This source code is licensed under the MIT license found in the # LICENSE file in the root directory of this source tree. +# See https://github.com/facebook/metro/pull/1086 regarding handling of hotfix tags + # Reduce a semver tag name to a Metro's release branch naming convention, eg v0.1.2-alpha.3 -> 0.1.x -RELEASE_BRANCH=$(echo "$CIRCLE_TAG" | awk -F. '{print substr($1, 2) "." $2 ".x"}') +RELEASE_BRANCH=$(echo "$RAW_TAG_NAME" | awk -F. '{print substr($1, 2) "." $2 ".x"}') # Does a release branch contain this tag (hotfix workflow) -TAG_ON_RELEASE_BRANCH=$(git branch -a --contains "$CIRCLE_TAG" | grep -cFx " remotes/origin/$RELEASE_BRANCH" || true) +TAG_ON_RELEASE_BRANCH=$(git branch -a --contains "$RAW_TAG_NAME" | grep -cFx " remotes/origin/$RELEASE_BRANCH" || true) echo "Tag is on release branch $RELEASE_BRANCH: $TAG_ON_RELEASE_BRANCH" # Does main contain this tag (regular release workflow) -TAG_ON_MAIN=$(git branch -a --contains "$CIRCLE_TAG" | grep -cFx ' remotes/origin/main' || true) +TAG_ON_MAIN=$(git branch -a --contains "$RAW_TAG_NAME" | grep -cFx ' remotes/origin/main' || true) echo "Tag is on main branch: $TAG_ON_MAIN" if [ $TAG_ON_RELEASE_BRANCH -eq $TAG_ON_MAIN ]; then @@ -25,4 +27,4 @@ NPM_TAG="latest" [ "$TAG_ON_RELEASE_BRANCH" -eq 1 ] && NPM_TAG="${RELEASE_BRANCH%.x}-stable" echo "Publishing with --tag=$NPM_TAG" -npm run publish --tag="$NPM_TAG" +npm run publish --tag="$NPM_TAG" --dry-run diff --git a/.github/workflows/build-and-test.yml b/.github/workflows/build-test-and-deploy.yml similarity index 53% rename from .github/workflows/build-and-test.yml rename to .github/workflows/build-test-and-deploy.yml index d9dc0bded1..eb77f3ed4a 100644 --- a/.github/workflows/build-and-test.yml +++ b/.github/workflows/build-test-and-deploy.yml @@ -1,13 +1,18 @@ -name: facebook/metro/build-and-test +name: facebook/metro/build-test-and-deploy on: workflow_call: pull_request: types: [opened, synchronize] + push: + tags: +# The job is triggered for any tag push. Tag format validation will be done +# as part of the deploy job for clearer error reporting on tag formatting + - '**' # head_ref is per PR, so this ensures that updating the latest PR commit # will cancel the previous run of the workflow and trigger a new one concurrency: - group: "build-and-test-${{ github.head_ref }}" + group: "build-test-and-deploy-${{ github.head_ref }}" cancel-in-progress: true defaults: @@ -50,3 +55,32 @@ jobs: node-version-type: ${{ matrix.node-version-type }} - name: Run Jest Tests run: yarn jest --ci --maxWorkers 4 --reporters=default --reporters=jest-junit --rootdir='./' + + deploy: + if: ${{ startsWith(github.ref_type, 'tag') }} + runs-on: ubuntu-latest + name: "Deploy" + steps: + - uses: actions/checkout@v4 + - uses: ./.github/actions/yarn-install + - name: Check Tag Format + id: check_tag + # successful version example: v22.33.44 and v0.80.9-alpha + run: | + if [[ $GITHUB_REF =~ ^refs/tags/v\d+(\.\d+){2}(-.*)?$ ]]; then + echo "valid=true" >> $GITHUB_OUTPUT + else + echo "valid=false" >> $GITHUB_OUTPUT + fi + - if: steps.check_tag.outputs.valid == 'false' + uses: actions/github-script@v7 + with: + script: | + core.setFailed('ERROR! Wrong tag format failed the package deployment!') + - run: echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" >> ~/.npmrc + - if: steps.check_tag.outputs.valid == 'true' + run: "./.github/scripts/publish.sh" + env: + RAW_TAG_NAME: ${{ github.ref_name }}" + - run: rm ~/.npmrc +