Before installation, please make sure you have the latest version of Yarn installed.
Please note,
- You should have your own development certificate.
- Save any certificates, p12 files etc... to our developer repo.
- "Romulus - iOS Development" provisioning can and should be edited.
- For release, we use a shared distribution certificate "Romulus", this should not be edited, deleted or regenerated.
Follow this guide to setup your development certificate.
Once your certificate is all setup, head back to the Apple developer portal and edit the existing "Romulus - iOS Development" provisioning profile to include your certificate (and any devices you wish to add). Download the new provisioning profile and you should be good to go.
Make sure you clone down our developer repo and double click the Certificates.p12
from the romulus/certificates/production/simpleweb
folder.
This is a shared certificate, you do not need to generate a new one each time.
After this is installed, please download the "Romulus - iOS Distribution" provisioning profile from the Apple developer site.
Install JavaScript dependencies with yarn
.
$ yarn install
React Native uses a development server to bundle up your code, you'll need this running before launching the app in a simulator.
$ yarn run start
You can use the React Native CLI to easily run the app onto the iOS and Android simulators.
$ yarn global add react-native-cli
Once installed you can then run the app onto each platform’s respective simulator.
$ react-native run-ios
$ react-native run-android
The iOS version (may) use Pods, and requires to be run via it's Xcode Workspace. If you have build errors with the iOS command above, please open Romulus.xcworkspace
and run your builds from there.
This project uses Jest for testing. You can run the tests once, have Jest continually watch for changes or ask it to produce a coverage report.
$ yarn run test
$ yarn run test:watch
$ yarn run coverage
With Jest, tests can live anywhere within the codebase, the majority however live in the __tests__
folder at the root of the project. Any folder with the same name or files ending in .test.js
will also be included when running Jest.
Romulus uses Flow to type check the app. If there are missing definitions for external libraries (AKA, you receive lots of Flow errors when using 3rd party code) you can use flow-typed
to fill in any missing gaps.
It’s worth running the update command every so often to keep things in check.
$ flow-typed update
To get Deep Linking working, it requires a few additional steps for iOS and Android. The steps can be found on the react navigation docs.
The source app icons is located in App/Assets/AppIcon.png
. The icons for Android and iOS are generated with rn-toolbox
. Please refer to their documentation to generate new icons.
Typically though the command should be something along these lines.
$ yo rn-toolbox:assets --icon App/Assets/AppIcon.png
Testing builds should be configured to point towards staging and released using Fabric.
To configure the build for staging, please place staging configuration into .env.production
. While this is confusing, unfortunately the plugin we are using to populate the environment looks for this file when the app is built in release mode, rather than being environment specific.
For iOS, you will need to produce a release build using the Romulus - iOS Development
provisioning profile. Please make sure everyone’s UUID in the profile you wish to test with. Please refer to this guide for releasing on Fabric.
For Android, simply build the project using the instructions below and then follow the Beta Process Walkthrough guide.
You will need to make sure Crashlytics is installed in Android Studio, follow these instructions if you don’t have it setup.
When producing a new build you will need to bump the version number. This is handled more or less automatically through the version in the package.json
.
For iOS you need to run the following command which automatically updates the XCode project with the version inside the package.json
. It also increments the build number.
$ yarn run bump
Android’s version is dynamically generated using it’s Gradle files.
If there's ever any issues with this flow, please refer to this article.
In XCode build to the "Generic iOS Device" and then archive the build. Building (as opposed to running) will use the "Signing (Release)" profile, the provisioning profile for this must be "Romulus - iOS Distribution".
Once archived simply open the Organizer in XCode and upload the build.
From https://github.com/simpleweb/developer.apple.com/tree/master/romulus/android, download the romulus.keystore
file and place it into android/app
.
Then take the environment variables from gradle.properties
and and them into your own properties file located in ~/.gradle/gradle.properties
.
Once these are both setup correctly, go into the android
directory and run...
$ ./gradlew assembleRelease
This should leave you with a signed APK located in android/app/build/outputs/apk/app-release.apk
.
After each build, please create a commit along the lines of "Release 0.1.0" and push it to Github. Following that, create a release and named "v0.1.0", include any release notes and attach both iOS and Android binaries (zipped).