Test Observability on Espresso
Quick start guide to integrate BrowserStack Test Observability with Espresso
Prerequisites
- You have an account with BrowserStack (even a free trial works) and can get the Username and Access Key from your account profile.
- You have a pre-existing Espresso test suite integrated with BrowserStack App Automate.
- Espresso tests are built into a separate
apk
file from your app. Hence, you will need access to both the app (.apk
or.aab
) and the Espresso test suite (separate.apk
file).
.apk
files and want to try App Automate, you can download our sample Calculator app and Calculator test-suite. Alternatively, check out our Espresso sample GitHub repository.
Integrate with Test Observability
Add the gradle plugin and the SDK dependency
Add the gradle plugin under plugins
and the BrowserStack SDK dependency under dependencies
in the build.gradle
file of the app.
plugins {
id 'com.browserstack.gradle-tool'
}
dependencies {
androidTestImplementation group: 'com.browserstack', name: 'browserstack-java-sdk', version: '1.21.0'
}
Add mavenCentral and the classpath for android tools
Add mavenCentral
under buildscript
at root level and the classpath for android tools under dependencies in the build.gradle
file.
buildscript {
repositories {
...
mavenCentral()
}
dependencies {
...
classpath 'com.android.tools.build:gradle:<AGP_version>'
classpath 'com.browserstack:gradle-tool:1.0.0'
}
}
Build the main and the test apk
Use the command that you usually use to build the main and the test apk. Some of the commands generally used are gradle assembleDebug
and gradle assembleAndroidTest
.
Upload your app
Upload your Android app (.apk
or .aab
file) to BrowserStack servers using a REST API request.
Use the following sample cURL comman to upload an app:
curl -u "YOUR_USERNAME:YOUR_ACCESS_KEY" \
-X POST "https://api-cloud.browserstack.com/app-automate/espresso/v2/app" \
-F "file=@/path/to/app/file/Application-debug.apk"
You can refer to the App Automate Espresso guide for more details and a sample request response.
Upload your test suite
Upload your Espresso test suite (.apk
) file to BrowserStack servers using our REST API.
The following sample cURL command shows how to upload a test suite:
curl -u "YOUR_USERNAME:YOUR_ACCESS_KEY" \
-X POST "https://api-cloud.browserstack.com/app-automate/espresso/v2/test-suite" \
-F "file=@/path/to/app/file/Application-debug-test.apk"
You can refer to the App Automate Espresso guide for more details and a sample request response.
Run your test suite
After you upload your app and test suite to BrowserStack servers, send an API request with testObservability
parameter set as true
and other parameters, to start the test execution as shown in the following sample cURL request:
curl -u "YOUR_USERNAME:YOUR_ACCESS_KEY" \
-X POST "https://api-cloud.browserstack.com/app-automate/espresso/v2/build" \
-d '{"app": "bs://8ec7295713fd5928ce0e7a35e7b533b6285fc5ca", "testSuite": "bs://4413d5a5b75f32ddbbb8f50db5963d2cabef9c56", "devices": ["Google Pixel 6 Pro-13.0"], "testObservability": true, "project" : "Espresso_Testpsq", "o11y_buildTags": ["build tag 1", "build tag 2"], "o11y_hostInfo": {"hostname": "samplehostname"}, "o11y_ciInfo":{"name":"Jenkins","build_url":"https://github.com","job_name":"workflow_name","build_number":"run-id"}, "o11y_buildRunIdentifier": "Sample Build Identifier", "o11y_reRun": false}' \
-H "Content-Type: application/json"
The parameters related to Test Observability in the above sample curl request are the following:
-
project
: The project name under which the test will be organized. -
o11y_buildTags
: Any custom build tags (optional) you want to associate with the build. -
o11y_hostInfo
: An optional parameter with information related to the host including the host name. -
o11y_ciInfo
: An optional parameter with information related to the CI build including the name of the CI tool, build URL, job name, and build number. -
o11y_buildRunIdentifier
: An optional custom identifier for the build run. You can merge multiple reports into a single report using this parameter. -
o11y_reRun
: Set this totrue
for re-runs of your suite. By default, this parameter is set tofalse
.
Post build run completion, you will see the build URL of Test Observability in your console. Alternatively, you can also navigate to your build run using Build Runs.
We're sorry to hear that. Please share your feedback so we can do better
Contact our Support team for immediate help while we work on improving our docs.
We're continuously improving our docs. We'd love to know what you liked
We're sorry to hear that. Please share your feedback so we can do better
Contact our Support team for immediate help while we work on improving our docs.
We're continuously improving our docs. We'd love to know what you liked
Thank you for your valuable feedback!