From 03a7daaa894df9fba05c907037a90bb74d82caa7 Mon Sep 17 00:00:00 2001 From: Brian Beckerle <49686530+brainbicycle@users.noreply.github.com> Date: Tue, 17 Oct 2023 14:23:06 -0400 Subject: [PATCH] build(ci): workflow review take 2 (#9429) * Revert "Revert: "build(ci): workflow review" (#9414)" This reverts commit b2d1c70c5d9d3995403ba897fc5b9e727c6dbfd5. * remove require check for faster testing * generate checksums in android prep * try generating first * remove workspace attach for now, move checkout up * restore workspace commands * require build-test-js to check cache * don't quit early for now * try clearing out the project * restore other required jobs * quit early again --- .circleci/config.yml | 115 ++++++-------------------- .github/workflows/release-ios-app.yml | 24 ------ docs/deploy_to_app_store.md | 18 +--- scripts/release-ios-app | 7 -- scripts/release-ios-app-branch | 11 --- 5 files changed, 29 insertions(+), 146 deletions(-) delete mode 100644 .github/workflows/release-ios-app.yml delete mode 100755 scripts/release-ios-app delete mode 100755 scripts/release-ios-app-branch diff --git a/.circleci/config.yml b/.circleci/config.yml index 4794787c30b..4c4d5cdedac 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -66,7 +66,7 @@ commands: steps: - restore_cache: keys: - - v7-gems-{{ checksum "Gemfile.lock" }}-{{ arch }} + - v8-gems-{{ checksum "Gemfile.lock" }}-{{ arch }} - run: name: Bundle install command: bundle check || bundle install @@ -112,16 +112,6 @@ commands: steps: - attach_workspace: at: ../workspace - - run: - name: Clear project dir - command: | - rm -rf /Users/distiller/project - - checkout - - attach_workspace: - at: . - - install-node - - setup-awscli - - setup-env-file - restore_cache: keys: - v9-test-success-{{ checksum "../workspace/.manifests/android_native" }} @@ -132,6 +122,14 @@ commands: then circleci step halt fi + - run: + name: Clear project dir + command: | + rm -rf /home/circleci/project/* + - checkout + - install-node + - setup-awscli + - setup-env-file - install-node-modules - run-relay-compiler - update-echo @@ -221,9 +219,7 @@ jobs: resource_class: large steps: - checkout - - node/install-packages: - cache-version: "v2" - pkg-manager: yarn + - install-node-modules - run-relay-compiler - run: command: yarn jest --ci --forceExit --logHeapUsage --runInBand --reporters=default --reporters=jest-junit --shard=$(expr $CIRCLE_NODE_INDEX + 1)/$CIRCLE_NODE_TOTAL @@ -236,20 +232,6 @@ jobs: - store_test_results: path: ./reports/junit/ - type-check: - executor: - name: node/default - tag: "16.18.0" - resource_class: small - steps: - - checkout - - node/install-packages: - cache-version: "v2" - pkg-manager: yarn - - run-relay-compiler - - run: - command: yarn type-check - update-metaphysics: executor: name: node/default @@ -272,8 +254,17 @@ jobs: resource_class: small steps: - checkout - - node/install-packages: - pkg-manager: yarn + - install-node-modules + - run-relay-compiler + - run: + command: yarn type-check + - run: + name: Check Branch and Exit Early if Ignored + command: | + if [[ "$CIRCLE_BRANCH" == "main" || "$CIRCLE_BRANCH" == "beta-ios" || "$CIRCLE_BRANCH" == "beta-android" ]]; then + echo "On ignored branch ($CIRCLE_BRANCH). Exiting early." + circleci-agent step halt + fi - run: name: Danger command: yarn danger ci --verbose @@ -358,10 +349,6 @@ jobs: then circleci step halt fi - - run: - name: Clear project dir - command: | - rm -rf /Users/distiller/project - checkout - attach_workspace: at: . @@ -426,19 +413,6 @@ jobs: name: Deploy if beta - play store and firebase command: ./scripts/deploy-if-beta-branch-android BOTH - release-ios-app: - environment: - BUNDLE_PATH: .vendor # path to install gems and use for caching - macos: - xcode: 14.3.1 - resource_class: macos.m1.medium.gen1 - steps: - - checkout - - install-gems - - run: - name: Release app version - command: ./scripts/release-ios-app-branch - workflows: version: 2 nightly: @@ -463,14 +437,6 @@ workflows: jobs: - check-flags - release-ios-app-workflow: - jobs: - - release-ios-app: - filters: - branches: - only: - - release-ios-app - test-build-deploy: jobs: - detect-secrets: @@ -478,26 +444,9 @@ workflows: branches: ignore: - main - - release - - staging - - - type-check: - filters: - branches: - ignore: - - app_store_submission - - play_store_submission - check-code: context: danger-github-oss - filters: - branches: - ignore: - - main - - beta-ios - - beta-android - - app_store_submission - - play_store_submission - check-and-deploy: filters: @@ -505,19 +454,9 @@ workflows: only: - main - - test-js: - filters: - branches: - ignore: - - app_store_submission - - play_store_submission + - test-js - - build-test-js: - filters: - branches: - ignore: - - app_store_submission - - play_store_submission + - build-test-js - horizon/block: context: horizon @@ -532,12 +471,10 @@ workflows: filters: branches: ignore: - - app_store_submission - - play_store_submission - beta-android requires: - test-js - - type-check + - check-code - build-test-js - horizon/block @@ -545,12 +482,10 @@ workflows: filters: branches: ignore: - - app_store_submission - - play_store_submission - beta-ios requires: - test-js - - type-check + - check-code - build-test-js - horizon/block diff --git a/.github/workflows/release-ios-app.yml b/.github/workflows/release-ios-app.yml deleted file mode 100644 index 25ebc99d23a..00000000000 --- a/.github/workflows/release-ios-app.yml +++ /dev/null @@ -1,24 +0,0 @@ -# We use a github action in order for us to bypass our CircleCI -# configruation of only triggerening builds on main and PRs -name: ZZ-Cross-CI Trigger release iOS app to users 🚨 - -on: - push: - branches: [release-ios-app] - -permissions: - contents: read - -jobs: - build: - permissions: - contents: none - runs-on: ubuntu-latest - steps: - - name: 🚨 Trigger release ios app to users - run: | - curl \ - -X POST \ - --header "Content-Type: application/json" \ - -d '{"branch": "release-ios-app"}' \ - https://circleci.com/api/v1.1/project/github/artsy/eigen/build?circle-token=${{ secrets.CircleToken }} diff --git a/docs/deploy_to_app_store.md b/docs/deploy_to_app_store.md index cd4af08c680..7fa89ab2248 100644 --- a/docs/deploy_to_app_store.md +++ b/docs/deploy_to_app_store.md @@ -9,25 +9,15 @@ Eigen's beta pre-submission checklist has [moved into Notion 🔐](https://www.n ## Preparing to Ship a Final Version 1. Start a branch from main. -1. Update [`release_notes.txt`](https://github.com/artsy/eigen/blob/main/fastlane/metadata/en-US/release_notes.txt) with the **user-facing** release notes for this version. +2. Update [`release_notes.txt`](https://github.com/artsy/eigen/blob/main/fastlane/metadata/en-US/release_notes.txt) with the **user-facing** release notes for this version. - See [previous examples](https://github.com/artsy/eigen/commits/main/fastlane/metadata/en-US/release_notes.txt) of release notes. - Share the notes with the #practice-mobile channel in Slack for feedback. - Commit, push the changes, make a PR from your branch to main. -1. Run `./scripts/promote-beta-to-submission-ios`. This will submit the **most recent beta** for App Store review +3. Run `./scripts/promote-beta-to-submission-ios`. This will submit the **most recent beta** for App Store review -### What about IDFA? +Our App Store releases are set to release automatically once Apple approves the app. You can check the status of the build in app store connect, a message will also be sent to mobile [at] artsymail [dot] com once the app is approved. -We _do_ use the IDFA to attribute app installations to previously service advertisements. This should be handled for you. - -## Release to App Store - -Our App Store releases are done manually, instead of automatically once Apple approves the app. Don't release unless you are available over the next few hours to monitor Sentry for errors. - -> _When the app is approved for release, a slack message is sent to notify the #practice-mobile channel and an email from Apple Store Connect is sent to mobile [at] artsymail [dot] com_ - -1. Run `./scripts/release-ios-app` -2. Monitor [Sentry 🔐](https://sentry.io/artsynet/eigen/) in the #practice-mobile channel on Slack for any errors (all production errors are sent to Slack when they first occur). -3. Make sure to let the team know over at [#dev 🔐](https://artsy.slack.com/archives/C02BC3HEJ)!. Don't forget to thank everyone who contributed 💜 +4. Make sure to let the team know over at [#dev 🔐](https://artsy.slack.com/archives/C02BC3HEJ)!. Don't forget to thank everyone who contributed 💜 ## Prepare for the Next Release diff --git a/scripts/release-ios-app b/scripts/release-ios-app deleted file mode 100755 index 7a333162e0a..00000000000 --- a/scripts/release-ios-app +++ /dev/null @@ -1,7 +0,0 @@ -#!/usr/bin/env bash -set -euxo pipefail - - -source ./scripts/source-for-bash-env - -git push origin "${LOCAL_BRANCH}:release-ios-app" -f --no-verify diff --git a/scripts/release-ios-app-branch b/scripts/release-ios-app-branch deleted file mode 100755 index 7585cd4bf07..00000000000 --- a/scripts/release-ios-app-branch +++ /dev/null @@ -1,11 +0,0 @@ -#!/usr/bin/env bash -set -euxo pipefail - - -source ./scripts/source-for-bash-env - -if [ "${LOCAL_BRANCH}" == "release-ios-app" ]; then - ./scripts/setup-fastlane-env - bundle exec fastlane update_plugins - bundle exec fastlane release_ios_app -fi