Graybox E2E Tests and Automation Library for Mobile
- About
- Getting Started
- See it in Action
- The Detox API
- Dealing with flakiness
- Contributing to detox
- Some implementation details
- License
High velocity native mobile development requires us to adopt continuous integration workflows, which means our reliance on manual QA has to drop significantly. The most difficult part of automated testing on mobile is the tip of the testing pyramid - E2E. The core problem with E2E tests is flakiness - tests are usually not deterministic. We believe the only way to tackle flakiness head on is by moving from blackbox testing to graybox testing and that's where detox comes into play.
Please note that this library is still pre version 1.0.0 and under active development. The NPM version is higher because the name "detox" was transferred to us from a previous inactive package.
This is a step-by-step guide to help you add detox to your project.
If you used previous detox version, follow the migration guide.
-
Install the latest version of
brew
. -
If you haven't already, install Node.js
brew update && brew install node
-
You will also need
fbsimctl
installed:brew tap facebook/fb && brew install fbsimctl --HEAD
-
Detox CLI
detox-cli
package should be installed globally, enabling usage of detox command line tools outside of your npm scripts.npm install -g detox-cli
-
If you do not have a
package.json
file in the root folder of your project, create one by runningnpm init
Follow the on screen instructions.
By default, Xcode uses a randomized hidden path for outputting project build artifacts, called DerivedData. For ease of use (and better support in CI environments), it is recommended to change the project build path to a more convenient path.
- With your project opened in Xcode, select menu
File
►Project Settings...
. Click onAdvanced...
, selectCustom
and from the drop-down menu, selectProject-relative Location
. - Build artifacts will now be created in a
DerivedData
folder next to yourxcodeproj
project.
-
Install detox:
npm install detox --save-dev
-
Install mocha:
npm install mocha --save-dev
-
Add detox to your
package.json
:"detox": { "configurations": { "ios.sim.release": { "binaryPath": "ios/build/Build/Products/Release-iphonesimulator/example.app", "build": "xcodebuild -project ios/example.xcodeproj -scheme example -configuration Release -sdk iphonesimulator -derivedDataPath ios/build", "type": "simulator", "name": "iPhone 7" } } }
For full configuration options see the options section below.
- Create an
e2e
folder in your project root. - Create
mocha.opts
file with this content. - Create
init.js
file with this content. - Create your first test!
myFirstTest.spec.js
with content similar to this.
By using the detox
command line tool, you can build and test your project easily.
-
Build your app:
detox build
-
Test your app:
detox test
That's it!
configurations
holds all the device configurations, if there is only one configuration in configurations
detox build
and detox test
will default to it, to choose a specific configuration use --configuration
param
Configuration Params | Details |
---|---|
binaryPath |
relative path to the ipa/app due to be tested (make sure you build the app in a project relative path) |
type |
device type, currently only simulator (iOS) is supported |
name |
device name, aligns to the device list avaliable through fbsimctl list for example, this is one line of the output of fbsimctl list : `A3C93900-6D17-4830-8FBE-E102E4BBCBB9 |
build |
[optional] build command (either xcodebuild , react-native run-ios , etc...), will be later available through detox CLI tool. |
Detox can either initialize a server using a generated configuration, or can be overriden with a manual configuration:
"detox": {
...
"session": {
"server": "ws://localhost:8099",
"sessionId": "YourProjectSessionId"
}
}
Applies when using detox-cli
by running detox test
command, default is e2e
.
"detox": {
...
"specs": "path/to/tests"
}
In your detox config (in package.json) paste your build command into the configuration's build
field.
The build command will be triggered when running
You can choose to build your project in any of these ways...
-
If there's only one configuration, you can simply use:
detox build
-
To choose a specific configuration:
detox build --configuration yourConfiguration
-
Building with xcodebuild:
xcodebuild -project ios/YourProject.xcodeproj -scheme YourProject -sdk iphonesimulator -derivedDataPath ios/build
-
Building using React Native, this is the least suggested way of running your build, since it also starts a random simulator and installs the app on it.
react-native run-ios
Note: remember to update the
app
path in yourpackage.json
.
-
If there's only one configuration, you can simply use:
detox test
-
For multiple configurations, choose your configuration by passing
--configuration
param:detox test --configuration yourConfiguration
Open the React Native demo project and follow the instructions
Not using React Native? you now have a pure native demo project too
Check the API Reference or see detox's own E2E test suite to learn the test API by example.
See the Flakiness handbook
If you're interested in working on detox core and contributing to detox itself, take a look here.
- We let you write your e2e tests in JS (they can even be cross-platform)
- We use websockets to communicate (so it should be super fast and bi-directional)
- Both the app and the tester are clients, so we need the server to proxy between them
- We are relying on EarlGrey as our gray-box native library for iOS (espresso for Android later on)
- The JS tester controls EarlGrey by remote using a strange JSON protocol
- Instead of wrapping the zillion API calls EarlGrey supports, we implemented a reflection mechanism
- So the JS tester in low level actually invokes the native methods.. freaky
- We've abstracted this away in favor of a protractor-like api, see
demo-react-native/e2e/example.spec.js
- See everything EarlGrey supports here and in this cheatsheet
- We use fbsimctl to control the simulator from the test, restart the app, etc
- detox by itself and all original source code in this repo is MIT
- detox relies on some important dependencies, their respective licenses are: