Skip to content
/ flank Public
forked from Flank/flank

a massively-parallel Android test runner for Firebase test lab

License

Notifications You must be signed in to change notification settings

thalescm/flank

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Flank Build Status

Flank is a Firebase Test Lab tool for massively-scaling your automated Android tests. Run large test suites across many devices/versions/configurations at the same time, in parallel. Flank can easily be used in a CI environment where Gradle (or similar) first builds the APK:s and then Flank is used to execute the tests.

To use Flank, please sign up for Firebase Test Lab and install the Google Cloud SDK.

Setup

Download

Either download Flank from here

or

Use curl:

curl --location --fail https://dl.bintray.com/flank1/Flank/Flank-1.5.0.jar --output Flank-1.5.0.jar

Run Tests

To runs tests with Flank you will need the app and test apk's. You can specify in which package you would like tests to run. A single class or test can also be executed (package_name.class_name#method_name). If no package name is provided all the tests will be executed. Usage:

java -jar Flank-1.5.0.jar <app-apk> <test-apk> [package-name]

When the executions are completed Flanks will fetch the xml result files, add device name to the tests and store the files in a folder named: results.

Configure Flank

It's possible to configure Flank by including a Java properties file in the root folder: config.properties

Following properties can be configured:

deviceIds: The ID:s of the devices to run the tests on
os-version-ids: The API-levels of the devices to run the tests on
orientations: The orientations, portrait, landscape or both
locales: The device locales
environment-variables: To set environment variables. Can also be used to enable code coverage 
directories-to-pull: If directories from the device should be pulled
use-orchestrator: To enable Android Test Orchestrator
shard-timeout: Timeout in minutes for each shard 
shard-duration: Duration in seconds for each shard

numShards: Number of shards
shardIndex: If a specific shard should be executed
debug-prints: If debug prints should be enabled
fetch-xml-files: If the result xml files should be fetched
fetch-bucket: If the bucket containing logs and artifacts should be fetched
gcloud-path: The path to the glcoud binary
gsutil-path: The path to the gsutil binary
gcloud-bucket: The Google Cloud Storage bucket to use. If not specified Flank will create one. 
use-gcloud-beta: If gcloud beta should be used

Example of a properties file:

deviceIds=Nexus5X,Nexus6P  
os-version-ids=23,24   
orientations=portrait  
locales=en,sv  
environment-variables=coverage=true,coverageFile=/sdcard/tempDir/coverage.ec
directories-to-pull=/sdcard
shard-timeout=5 
shard-duration=120  

numShards=  
shardIndex= 
debug-prints=false  
fetch-xml-files=true
fetch-bucket=true
gcloud-path=
gsutil-path=

Configurable Shards

Flank supports configurable shard durations. Instead of creating one shard per test case Flank can create shards that contain tests that add up to a given duration. This feature was introduced to make Flank faster while also saving cost (seconds are round up to minutes by Firebase test lab). By default Flank will try to create shards with tests adding up to 2 minutes in execution time.

First time a new app is tested each test is run in its own shard so that Flank can save the individual execution times. This is also the case for new tests that are introduced. The execution times for tests are saved in a file: flank.tests. This file is used by Flank to create shards and is backed up in your google cloud bucket. Open the file in an editor to edit the execution times. Create an empty flank.tests in the root Flank folder to start from a clean slate.

shard-duration can be set in config.properties. Default shard duration is 120 seconds. To enable one test per shard set shard-duration to -1 or specify a custom number of shards with numShards.

Troubleshooting

Please enable debug mode debug-prints:true in the properties file if it's not working correctly.

If Flank hangs and nothing seems to be happening (even when debug mode is enabled) make sure the correct user (registered with Firebase) is logged into Firebase. Please also see Google Cloud Storage Authentication.

If you see AccessDeniedException: 403 verify that:

  • The GCloud SDK is on the latest version
  • The Firebase project is on a paid subscription (for free accounts specify the default bucket with property: gcloud-bucket)
  • The Firebase account and project ID are in sync

Follow below steps to set it:

gcloud components update - Update the GCloud SDK

gcloud config list - To view gcloud SDK properties.

gcloud auth login - To set gcloud to the correct google account.

gcloud config set project <idOfYourProject> - To set gcloud to the correct project ID.

If you are using the terminal in OS X and Flank gets stuck at around 250 shards its because of a setting in OS X. To fix it please follow these instructions.

About

a massively-parallel Android test runner for Firebase test lab

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 90.9%
  • Kotlin 8.8%
  • Shell 0.3%