Skip to content

A sample React Native app showing how to setup CI using App Center and Bitrise

Notifications You must be signed in to change notification settings

anchetaWern/ReactNativeCI

Repository files navigation

ReactNativeCI

A sample React Native app showing how to use Visual Studio App Center and Bitrise as a Continuous Integration server.

This branch contains the final output of the Getting started with continuous integration in React Native series.

Full tutorial is available at:

Note: the React Native code in this repo may be a little bit outdated and won't run immediately after you've followed the setup instructions. Be sure to refactor the code to use the more recent React Native syntax if it doesn't run for you.

Prerequisites

  • React Native development environment
  • Bitrise Account

Getting Started

  1. Clone the repo:
git clone https://github.com/anchetaWern/ReactNativeCI.git
cd ReactNativeCI
  1. On another directory, create a new React Native app on another directory:
react-native init ReactNativeCI --version [email protected]
  1. Copy the following files and folders from the repo you cloned over to the React Native project you created:
  • App.js
  • src
  • e2e
  • fileTransformer.js
  1. Upgrade your project to use Gradle 3 by updating the following files. Use this commit as basis:
  • android/build.gradle
  • android/gradle/wrapper/gradle-wrapper.properties
  1. Install additional packages and link them:
yarn add redux-saga react-native-simple-store redux react-redux prop-types
react-native link
  1. Run the app:
react-native run-android
react-native run-ios
  1. Install Detox and Mocha:
  1. Update the following files to match what's on this commit:
  • android/settings.gradle
  • android/build.gradle
  • android/app/build.gradle
  • android/app/src/androidTest/java/com/reactnativeci/DetoxTest.java
  1. Add the Detox config to the package.json file:
"detox": {
  "configurations": {
    "ios.sim.debug": {
      "binaryPath": "ios/build/Build/Products/Debug-iphonesimulator/reactnativeci.app",
      "build": "xcodebuild -project ios/reactnativeci.xcodeproj -scheme reactnativeci -configuration Debug -sdk iphonesimulator -derivedDataPath ios/build",
      "type": "ios.simulator",
      "name": "iPhone 5s"
    },
    "android.emu.debug": {
      "binaryPath": "./android/app/build/outputs/apk/debug/app-debug.apk",
      "build": "cd android && ./gradlew assembleDebug assembleAndroidTest -DtestBuildType=debug && cd ..",
      "type": "android.attached",
      "name": "192.168.57.101:5555" 
    }
  },
  "test-runner": "mocha",
  "specs": "e2e",
  "runner-config": "e2e/mocha.opts"
}

android.attached is for Genymotion emulator while android.emulator is for Android emulator installed with Android Studio.

Use avdmanager list avd or xcrun simctl list to find out which simulators or emulators are available on your machine.

  1. Build the app with Detox:
detox build -c android.emu.debug --reuse
detox build -c ios.sim.debug --reuse
  1. Run the app:
react-native run-android
react-native run-ios --simulator="iPhone 5s"
  1. Run the end-to-end tests:
detox test -c android.emu.debug --reuse
detox test -c ios.sim.debug --reuse
  1. Update jest config in package.json file:
	"jest": {
		"preset": "react-native",
		"moduleNameMapper": {
			"^.+\\.(jpg|jpeg|png)$": "RelativeImageStub"
		},
		"transform": {
			"\\.(jpg|jpeg|png|gif)$": "<rootDir>/fileTransformer.js"
		},

		"testMatch": ["<rootDir>/__tests__/*"]
	},
  1. Run the snapshot test:
yarn test
  1. Setup app on Bitrise (see full tutorial).
  2. Commit your changes and push to the repo:
git add .
git commit -m "initialize project"
git push origin --all

Built With

Donation

If this project helped you reduce time to develop, please consider buying me a cup of coffee :)

Buy Me A Coffee

About

A sample React Native app showing how to setup CI using App Center and Bitrise

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published