Skip to main content
No Result Found

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).
Note: If you do not have .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.

build.gradle
Copy icon Copy
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.

build.gradle
Copy icon Copy
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:

Terminal
Copy icon Copy
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.

Note: App upload will take a few seconds to about a minute, depending on the size of your app. Do not interrupt the curl command until you get the response back.

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:

Terminal
Copy icon Copy
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:

Terminal
Copy icon Copy
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 to true for re-runs of your suite. By default, this parameter is set to false.

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.

Visit Test Observability

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

Is this page helping you?

Yes
No

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!

Talk to an Expert
Download Copy Check Circle