From 6544a6c380d9361a1159792e00376b672810bb9a Mon Sep 17 00:00:00 2001 From: nriedman <108841122+nriedman@users.noreply.github.com> Date: Mon, 16 Sep 2024 09:44:18 -0700 Subject: [PATCH] Add input for custom command in firebase emulators:exec (#81) # Add option to run custom command right before fastlane in emulator execution. ## :recycle: Current situation & Problem In the ENGAGE-HF project, when we seed the emulator using the `npm run serve:seeded` command, the following command executes under the hood: `firebase emulators:exec --only auth,firestore,functions,storage --ui "npm run serve:seed && read -rd \"\""`. This spins up an emulator instance for the duration of the execution of the `"npm run serve:seed && read -rd \"\""` calls. `npm run serve:seed` executes the required functions to seed the emulator, and the `read -rd \"\"` then causes the emulator to continue running until the user cancels the operation. However, when integrating the seeding functionality into the CI for ENGAGE, we need to be able to have a seeded instance of the emulator for the duration of the fastlane testing call. The `read -rd \"\"` won't work for the self-hosted runner, as there is no way to cancel the emulator without canceling the workflow. Instead, we can introduce an input to the build-and-test workflow that allows us to pass a custom command to execute right before the `fastlane test` call. This custom command will then stay in effect throughout the lifespan of the emulator, which will shut down after the fastlane process finishes. ## :gear: Release Notes - Added an input for the custom command called `customfirebaseemulatorcommand` - Modified the execution of the fastlane command for the case where the `fastlanelane` argument is not empty, the `setupfirebaseemulator` argument is true, and the `firebaseemulatorimport` is empty. Currently, the workflow executes the following command to run the fastlane tests if there is no firebase import provided: ```shell firebase emulators:exec 'fastlane ${{ inputs.fastlanelane }}' ``` Instead, we replace this with the following: ```shell if [ -n "${{ inputs.customfirebaseemulatorcommand }}" ]; then firebase emulators:exec '${{ inputs.customfirebaseemulatorcommand }} && fastlane ${{ inputs.fastlanelane }}' else firebase emulators:exec 'fastlane ${{ inputs.fastlanelane }}' ``` This allows the following emulator command to be run: ```shell firebase emulators:exec 'npm run serve:seed && fastlane test' ``` ## :books: Documentation See description of `customfirebaseemulatorcommand` in `xcodebuild-or-fastland.yml`. ## :white_check_mark: Testing NA ### Code of Conduct & Contributing Guidelines By submitting creating this pull request, you agree to follow our [Code of Conduct](https://github.com/StanfordBDHG/.github/blob/main/CODE_OF_CONDUCT.md) and [Contributing Guidelines](https://github.com/StanfordBDHG/.github/blob/main/CONTRIBUTING.md): - [X] I agree to follow the [Code of Conduct](https://github.com/StanfordBDHG/.github/blob/main/CODE_OF_CONDUCT.md) and [Contributing Guidelines](https://github.com/StanfordBDHG/.github/blob/main/CONTRIBUTING.md). --- .github/workflows/xcodebuild-or-fastlane.yml | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/.github/workflows/xcodebuild-or-fastlane.yml b/.github/workflows/xcodebuild-or-fastlane.yml index 64664be..1546f35 100644 --- a/.github/workflows/xcodebuild-or-fastlane.yml +++ b/.github/workflows/xcodebuild-or-fastlane.yml @@ -129,6 +129,13 @@ on: required: false type: string default: '' + firebasejsonpath: + description: | + Path to the firebase.json file that is used to boot up the firebase emulator. + Defaults to the root of the project. + required: false + type: string + default: './firebase.json' googleserviceinfoplistpath: description: | Path to the GoogleService-Info.plist file that is replaced using the content found in the secret GOOGLE_SERVICE_INFO_PLIST. @@ -374,9 +381,9 @@ jobs: if [ -n "${{ inputs.firebaseemulatorimport }}" ]; then echo "Importing firebase emulator data from ${{ inputs.firebaseemulatorimport }}" - firebase emulators:exec --import=${{ inputs.firebaseemulatorimport }} 'fastlane ${{ inputs.fastlanelane }}' + firebase emulators:exec -c ${{ inputs.firebasejsonpath }} --import=${{ inputs.firebaseemulatorimport }} 'fastlane ${{ inputs.fastlanelane }}' else - firebase emulators:exec 'fastlane ${{ inputs.fastlanelane }}' + firebase emulators:exec -c ${{ inputs.firebasejsonpath }} 'fastlane ${{ inputs.fastlanelane }}' fi else fastlane ${{ inputs.fastlanelane }}