- Start the app:
yarn android:{env}
oryarn ios:{env}
(envs:dev
,staging
, andprod
) - Start metro bundler:
yarn start
- Lint the app:
yarn lint
- Test the app:
yarn test
- Install dependencies:
yarn
- Create a
.env.dev
file in the root directory of the project, based on the.env.example
sample file and the extra constants that you may need. This will be your development env.
You can also create .env.prod
, .env.staging
, and .env.qa
to define environment variables for production and staging.
- Rename your new project using
yarn rename
ornpm run rename
- Start on android or ios:
yarn android:{env}
oryarn ios:{env}
(envs:dev
,qa
,staging
, andprod
)
None
- Run the following command to install iOS pods
npx pod-install
- Create a new app in firebase with the Bundle Identifier of the schema that you will run
- Download a
GoogleService-Info.plist
- Run
xed -b ios
to open Xcode - Add the
GoogleService-Info.plist
to the project folder - Run
pod install
inside the./ios
folder
- Create a new app in firebase with the package with the suffix of the flavor you will run
- Download the
google-services.json
and move it to the./android/app
directory
The repo includes configuration for using GitHub Actions to run unit tests and code analysis: .github/workflows/test.yml
. This can be adapted as needed for specifics of each project. Both CodeClimate and Sonarqube integrations are included in the workflow and their required environment settings should be retrieved from the repo Secrets.
There's a folder named .fttemplates where you'll find a template you can use to create new components for your app, keeping the same folder conventions for all your components.
You must install Folder Templates extensions in Visual Studio Code to use this feature. You'll find it here.
If you install the extension you can create your components folder using the template by clicking on Create new templated folder button in the context menu.
Screen.Recording.2023-02-02.at.13.14.40.mov
- After adding the project to CC, go to
Repo Settings
- On the
Test Coverage
tab, copy theTest Reporter ID
- Set the copied value as environment variable
CC_TEST_REPORTER_ID
(and repo Secrets)
- Log into Sonarqube console (
SONAR_URL
) and create a new Project key(SONAR_PROJECT
) - Generate a token for the new project and copy it
- Set the token value as environment variable
SONAR_TOKEN
sonar-scanner \
-Dsonar.qualitygate.wait=true \
-Dsonar.host.url=$SONAR_URL \
-Dsonar.login=$SONAR_TOKEN \
-Dsonar.projectKey=$SONAR_PROJECT \
-Dsonar.scm.provider=git \
-Dsonar.java.binaries=/tmp \
-Dsonar.nodejs.executable=$(which node) \
-Dsonar.projectVersion=$(echo $GITHUB_SHA | cut -c1-8) \
-Dsonar.sources=. \
-Dsonar.projectBaseDir=. \
-Dsonar.javascript.lcov.reportPaths=coverage/lcov.info
-Dsonar.coverage.exclusions=**/spec.js,**/__mocks__/**,**/**.spec.js,**/**.config.js,**/rnbv.js,**/android/**,**/ios/**,**/**.styles.js,**/tests/**,**/__mocks__/**,**/httpClient/**,**/jest-setup.js,**/constants/**,**/assets/**,**/node_modules/**,**/coverage/**
🚧 UNDER CONSTRUCTION 🚧
🚧 UNDER CONSTRUCTION 🚧
- Make sure that the version was already bumped if it applies if not you can run the version bump script with
npm run bump
oryarn bump
. - Select on Xcode the scheme of the env you want to create the release for.
- For the device select generic iOS device.
- Then go to Product -> Archive.
- After it is done processing and the archive succeeds the organizer will open. Here is where you can see all the previously generated archives.
- The last step is to upload it to the App Store from there or release it Ad Hoc style.
The base is already equipped with three main environments: dev
, qa
, staging
, production
. All the env files you need to provide are as follows: .env.dev
, .env.qa
, .env.staging
, and .env.prod
.
If you want to add a new env here are the steps to follow:
- Create a new env file with the format
.env.{name}
.
- go to
android/app/build.gradle
and add the env file association toproject.ext.envConfigFiles
following the existing ones as example. - Scroll down to the
flavors
section and add a new flavor with the following format:
{name} {
applicationIdSuffix '.{name}'
minSdkVersion rootProject.ext.minSdkVersion
targetSdkVersion rootProject.ext.targetSdkVersion
}
- Inside
android/app/src
copy one of the existing env folders likestaging
and rename it with the name of your new flavor. - In that new folder you will see a folder called
values
and inside a file calledstrings.xml
. There you can set the app name that is going to appear for this flavor. You can also set special app icons for each flavor insideres
folder. - (optional) go ahead and add new scripts in the
package.json
file for this new env. As you can see, the other envs already have scripts to run, build and build release. This will make your development workflow a lot easier. - you might need to open the android folder in Android Studio and do File -> Sync project with grade files
- Last but not least, make sure that you add the new environment to the
bump
script at
We have in place a validation that will check if the env file exists and has all the variables defined before building the app. This is to avoid building the app with the wrong env file and having to wait for the build to fail to realize that.
Variables are defined in src/@types/env
and the validation is done in scripts/validation-env.ts
.
APP_ENV={dev | prod | staging | qa} react-native run-{android | ios}
Note: For iOS the validation occurs within the scripts/simulator.sh
script. For Android it occurs as an inline command in the package.json
scripts
You can use schemes to configure different app-icons, splash, bundle-ids, etc.
Schemes are a great way to manage multiple envs in TestFlight.
Fortunately the base already comes with the schemes you will probably need to get to production: ReactNativeBase-Develop
, ReactNativeBase-QA
, ReactNativeBase-Staging
and ReactNativeBase
which is for production use.
Each build target has its respective scheme already set up, they all have the same name as the build target except for the production one, that one is called ReactNativeBase-Prod
. This leaves ReactNativeBase
scheme free of an env setup just in case you don't want to use build targets.
To add a new build target do as follows:
🚧 UNDER CONSTRUCTION 🚧
If you are looking for something quick and easy in the short term, there is one more way you can run the app with a custom env file, just run:
ENVFILE=.env.{env} react-native run-ios
Open the project with XCode and in the files tree find ReactNativeBase/ReactNativeBase/Images.xcassets
file. There you can find a different App Icon file for each environment, and you can modify each with your own icons.
Open the project with Android Studio. Under android/app/src
you will find a folder for each environment. Each one contains the app icon in square and round version in different sizes. You can change these png files in all sizes to use your own app icon.
The package used to add the splash screen functionality was react-native-bootsplash and uses placeholder images.