Plugin for which integrates Firebase Test Lab with Android Project. Simplify running Android Tests on Firebase platform locally as well as on using Continuous integration.
- Jacek Marchwicki
- [Zbynek Konieczny] (https://github.com/zbynek)
- Automatic installation of
gcloud
command line tool - Creating tasks for testable
buildType
[By default it isdebug
. If you want to change it usetestBuildType "buildTypeName"
] - Creating tasks for every defined device and configuration separately [ including Instrumented / Robo tests ]
- Creating tasks which runs all configurations at once
- Ability to download tests results to specific location
- Ability to clear directory inside bucket before test run
- Instrumented tests sharding
- Readability
- Simplicity
- Remote and Local Testing
- Compatible with Gradle 3.0
- Instrumented Tests sharding for parallel test execution
-
If you don't have a Firebase project for your app, go to the Firebase console and click Create New Project to create one now. You will need ownership or edit permissions in your project.
-
Create a service account related with your firebase project with an Editor role in the Google Cloud Platform console - IAM/Service Accounts
-
Copy
Project ID
from Google Cloud Platform console - HOME -
Add plugin to your root project
build.gradle
:buildscript { repositories { maven { url "https://plugins.gradle.org/m2/" } } dependencies { classpath "firebase.test.lab:plugin:X.X.X" } }
-
Add configuration in your project
build.gradle
:apply plugin: 'firebase.test.lab' firebaseTestLab { keyFile = file("test-lab-key.json") googleProjectId = "your-project-app-id" devices { nexusEmulator { deviceIds = ["hammerhead"] androidApiLevels = [23] } } }
List of available devices
-
Run your instrumentations tests
./gradlew firebaseTestLabExecuteDebugInstrumentation
Or run robo tests
./gradlew firebaseTestLabExecuteDebugRobo
You can
// Setup firebase test lab plugin
firebaseTestLab {
// REQUIRED obtain service key as described inside README
keyFile = file("test-lab-key.json")
// REQUIRED setup google project id ad described inside README
googleProjectId = "your-project-app-id"
// If you want you can ignore test failures
// ignoreFailures = true
// If you prefer you can use your custom google storage bucket for storing build sources and results
// cloudBucketName = "your-custome-google-storage-bucket-name"
// If not specified default is: a timestamp with a random suffix
// cloudDirectoryName = "your-custome-directory-name"
// If you prefer to install gcloud tool manually you can set path by
// cloudSdkPath = "/user/cloud-sdk/bin"
// If you want to change default gcloud installation path (default is in build/gcloud directory)
// you can set environment variable `export CLOUDSDK_INSTALL_DIR=`/cache/your_directory/`
// REQUIRED
devices {
// REQUIRED add at least one device
nexusEmulator {
// REQUIRED Choose at least one device id
// you can list all available via `gcloud firebase test android models list` or look on https://firebase.google.com/docs/test-lab/images/gcloud-device-list.png
deviceIds = ["hammerhead"]
// REQUIRED Choose at least one API level
// you can list all available via `gcloud firebase test android models list` for your device model
androidApiLevels = [23]
// You can test app in landscape and portrait
// screenOrientations = [com.appunite.firebasetestlabplugin.model.ScreenOrientation.PORTRAIT, com.appunite.firebasetestlabplugin.model.ScreenOrientation.LANDSCAPE]
// Choose language (default is `en`)
// you can list all available via `gcloud firebase test android locales list`
// locales = ["en"]
// If you are using ABI splits you can filter selected abi
// filterAbiSplits = true
// abiSplits = ["armeabi-v7a", "arm64-v8a", "x86", "x86_64"]
// If you are using ABI splits you can remove testing universal APK
// testUniversalApk = false
// For instrumented test you can specify number of shards, which allows to split all the tests for [numShards] times and execute them in parallel
// numShards = 4
// You can set timeout (in seconds) for test
// timeout = 6000
// Enable Android Test Orchestrator more info at: https://developer.android.com/training/testing/junit-runner
// isUseOrchestrator = true // default false
// A list of one or more test target filters to apply (default: run all test targets)
// testTargets = ["size large"]
// Environment variables are mirrored as extra options to the am instrument -e KEY1 VALUE1
// environmentVariables = ["clearPackageData=true", "coverage=true"]
// The fully-qualified class name of the instrumentation test runner
// testRunnerClass = "com.my.package.MyRunner"
// Pass any custom param for gcloud
// customParamsForGCloudTool = --no-performance-metrics
}
// You can define more devices
someOtherDevices {
deviceIds = ["shamu", "flounder"]
androidApiLevels = [21]
}
}
}
For more precise test selection run
./gradlew tasks
to discover all available test options