After upgrading `react-native` to `0.72.5` we frequently started seeing the _red screen of death_ on both `Android` and `iOS` simulators right after the app was built and installed. This used to happen because our workflow required us to do the following : - `make run-clojure` - `make run-metro` - `make run-ios` OR `make run-android` The problem with this approach was after `metro` was started the `iOS`, `Android` build step would change the files that `metro` couldn't handle and hence metro would go out of sync. The quick fix back then was to restart `metro` terminal and to open the app again from the simulator. This was however not a good DX. This commit fixes that. We no longer rely on `react-native` cli to generate and deploy debug builds on simulators. We take control of the process via our own script. The new workflow introduced in this commit will first build the app, then install the app on the simulators and then start metro terminal. When `metro` is successfully running the script will then open the app. The new workflow now is : - `make run-clojure` - `make run-ios` OR `make run-android`
4.6 KiB
Description
This document provides information on how to start developing Status App.
Getting Started
To start developing start a shell for the platform you are interested in.
make shell TARGET=android
This step will take a while the first time as it will download all dependencies.
Development
There are three steps necessary to start development, in this case for Android:
make run-clojure
- Compiles Clojure into JavaScript, watches for changes on cljs files, and hot-reloads code in the app.make run-android
ormake run-ios
- Builds the Android/iOS app, starts it on the device and starts metro bundler.
The first two will continue watching for changes and keep re-building the app. They need to be ready first. The last one will exit once the app is up and ready.
Simulators and Devices
Android
You need to have an emulator like AVD, or Genymotion, or a real device running and visible to adb, before you run make run-android
.
iOS
Running on a simulator
We highly recommend using either the iPhone 11 Pro
or iPhone 13
simulator as its screen dimensions match with our design.
If you have Xcode v12.x
(and above) installed in your system, you need to follow the below steps to add iPhone 13
simulator:
- Open Xcode
- Menu
>
Window>
Devices and Simulators - Tap
+
button on bottom left - Select Device Type as
iPhone 13
- Leave the Simulator Name empty and tap on Create
NOTE ⚠️
Running make run-ios
will target iPhone 13
by default.
If you need to run on any other simulator, you can specify the simulator type by adding the SIMULATOR
flag:
make run-ios SIMULATOR="iPhone 13"
Running on a physical device
Some manual steps are necessary for developing on a physical iOS Device.
Build release
To build the app, you can simply run on of the following:
make release-android
make release-ios
For more make
targets run make help
.
Updating Dependencies
make nix-update-pods
- iOS CocoaPods dependencies (updatesios/Podfile
andios/Podfile.loc
)make nix-update-gradle
- Android Gradle/Maven dependencies (updatesnix/deps/gradle/deps.json
)make nix-update-clojure
- Clojure Maven dependencies (updatesnix/deps/clojure/deps.json
)make nix-update-gems
- Fastlane Ruby dependencies (updatesfastlane/Gemfile.lock
andfastlane/gemset.nix
)
Manual Steps
There are a few manual steps you might want to do in order to start contributing.
Genymotion Virtualization
Optionally set up Genymotion if you don't want to use Android Virtual Device:
Android Development Environment
You can also setup Android Development Environment + Simulator:
https://facebook.github.io/react-native/docs/getting-started.html
Configure GitHub Account
The optimal way of pushing to GitHub is using SSH instead of user/pass auth.
It's recommended that you add your public SSH key to your GitHub account.
Configure GPG Keys for signing commits
In order to increase security we require all commits in status-mobile
repo to be signed with a GPG key.
Steps:
- Generate a new GPG key
- Setup Git to use your GPG key
- Setup Git to sign commits
- Setup GitHub to validate commits
Physical iOS Device
To use a physical iPhone your device UDID must be added to provisioning profiles and your Apple account invited as Developer to Status team.
- Get your UDID of your iPhone.
- Request from someone with access like @cammellos or @jakubgs to
- Add the UDID to development devices on Apple Developer Portal.
- Invite your Apple account to be Developer in Status team.
- Run a build in XCode using the project from
status-mobile/ios
directory.
- You might see error:
Select a development team in the Signing & Capabilities editor
- Select
Status Research & Development GmbH
as the development team and rebuild again.
Once build finishes Status should start on your iPhone with its logs in terminal running make run-metro
.