For mobile development, there are two servers, the prod server, and the test server. Make sure to switch the server URL to the proper value in dev-mobile/lib/helper/API.dart .

There are two parts to this onboarding process: front-end and back-end. For the front-end part, it takes around 2 hours to complete. The goal is to locally build and run the iOS app on the simulator/Xcode and test the App on your phone using Testflight. For the backend part, it takes around 2-3 hours and the goal is to build the container and try to access both the prod and test servers.

FRONT-END 

Getting Started

In order to run the mobile app locally, follow the steps below:

  1. Install Xcode from App Store
  2. Install Flutter
    1. Use the response from flutter doctor  to guide you through any other necessary installations (e.g., Android Studio, Chrome, CocoaPods, etc.)
    2. We currently do not support the Android version of the App but it’s necessary to have Android Studio installed for Flutter to function properly. 
    3. If you encounter the "Bad CPU type in executable" error with flutter doctor , maybe this would help
    4. If you have trouble installing Cocoapods with ruby, try installing with brew install cocoapods 
  3. Pull the frontend-mobile repo from https://github.com/DIAPER-Project
  4. For local testing and development, use the test server by switching the server URL to https://mobile-test.diaper-project.com:5001/api in dev-mobile/lib/helper/API.dart .
    1. Note: the server URL may get updates in the future, please refer to the infra team/documentation for the new server url.
  5. Once flutter doctor  yields no error, proceed with the following steps in https://flutter.dev/docs/get-started/editor to build and run the app
    1. Navigate to the dev-mobile  directory.
    2. Simulation (two ways)
      1. You need to first open the iOS simulator by running open -a Simulator  in the terminal and then run flutter run .
      2. In VSCode, in the bottom toolbar, click "No Device," choose "iPhone 13" from the top drop-down menu, then run flutter run  in the terminal.
    3. If you get a BUILD FAILED error of "No file or variants found for asset: assets/mobile_secrets.json", you need to create such a JSON file. The contents of this JSON file can be found in the DIAPER Confidential box (ask Liz for access) under "mobile secrets".

Uploading to TestFlight

For the TestFlight build, use the prod server by switching the server URL to https://mobile-prod.diaper-project.com:5001/api in dev-mobile/lib/helper/API.dart . Note: the server URL may get updates in the future, please refer to the infra team/documentation for the new server URL.

You will first need to open the workspace (frontend-mobile/dev-mobile/ios/Runner.xcworkspace) in Xcode. 

Here are two very helpful and detailed guides. 

  1. From flutter
  2. This Medium post has some more screenshots that you may find useful to refer to

You may find them confusing, and indeed not all sections in the tutorials are relevant. The only necessary steps are:

  1. Modify the project settings
    • Follow the guide thoroughly
    • Make sure the signing setting is correct.
  2. Execute each step under the section "Submit App to TestFlight for the First time" in the Medium post.
  1.  
    • During Archive, if flutter.h not found
      1. Remove ios/Flutter/Flutter.podspec: rm ios/Flutter/Flutter.podspec
      2. flutter clean
      3. flutter run

Now Archive again, the problem should be fixed.


Once the app has been uploaded, go to App Store Connect and log in, you can find the new build (may take a while after uploading from Xcode) as in the screenshot. 

  • Click "Manage" and choose "None of the algorithms mentioned above"

  • Now you can click into the up-to-date build and invite testers

Then, download the app TestFlight from the App store and Redeem Diaper Cohort with the TestFlight invitation code. There, you can play with your most recent build.



  • No labels