Skip to main content

Getting Started

Introduction

Appium scripts can be used to automate testing on TV Labs devices through the TV Labs Appium proxy at appium.tvlabs.ai. This page explains how to use the TV Labs Appium proxy to run Appium scripts on TV Labs devices.

What to expect:

  • ⏱️ Duration: 10-15 minutes
  • 🎯 Audience: Developers interested in using Appium for automated testing on the TV Labs platform
  • 🧠 Outcome: Understanding how to use Appium for automated testing on the TV Labs platform

Also see: The Appium documentation provides examples for writing Appium scripts in various languages.

Overview

The TV Labs Appium proxy serves as a gateway to the TV Labs platform for Appium scripts. It enables users to run Appium-based test scripts on TV Labs devices from a local machine, CICD pipeline, or other environments. The proxy provides a single endpoint for device matching, application sideloading, and Appium server session management. Once a session starts, you can view a live stream of the device in the TV Labs sessions dashboard, along with Appium server logs and other session assets and information. Previous sessions are also accessible on this page.

important

Platform support is a work in progress. Please see Platforms for the list of currently supported platforms.

Connection Information

To use the TV Labs Appium proxy, you will first need to generate an API key from the API Keys page. This key will be used to authenticate requests to the TV Labs Appium proxy, and will tie the session to your TV Labs account.

After generating an API key, set your web driver endpoint to https://appium.tvlabs.ai:4723 and add the API key to the Authorization header as a Bearer token.

Example for NodeJS WebDriverIO script

const apiKey = "YOUR_API_KEY_HERE"

const webDriverOptions = {
hostname: "appium.tvlabs.ai",
port: 4723,
protocol: "https",
headers: {
Authorization: `Bearer ${apiKey}`
},
capabilities: { ... }
}
warning

The minimal required node version for the TV Labs Appium proxy is Node.js 20. If you are using an older version of Node.js, you will need to upgrade to at least version 20 to use the TV Labs Appium proxy.

If you're not sure which Node.js version you're using, we recommend to add the following line to your script to log the version instead of using the node -v command in the terminal, because the terminal may use a different version of Node.js than your script:

console.log(`Node.js version: ${process.version}`);

Capabilities

The TV Labs Appium proxy supports the following capabilities, in addition to the capabilities provided by Appium and driver specific capabilities.

The platformName, appium:automationName, and device connection capabilities are automatically added to the request based on the matched platform.

tvlabs:constraints (required)

The tvlabs:constraints capability matches your test script to a device on the TV Labs platform. It accepts a constraint query string, e.g. platform_key:ios. Read more about writing a constraint query in the device targeting documentation.

tvlabs:build (optional)

The tvlabs:build capability specifies a TV Labs build ID for sideloading onto the device before an Appium session starts. If the driver does not require a build ID, then you can omit this capability.

You can obtain a build ID from the App management page, or through the tvlabs upload command, which will upload your application to a secure blob storage:

❯ tvlabs upload -i ./path/to/application.zip
e6f2a4b1-8160-4147-8493-5e3aa18ddcc8

tvlabs:teleport_region (optional)

The tvlabs:teleport_region capability allows you to specify a dynamic teleport region for the Appium session. When the session starts, the device will have an IP address that exists in the specified region. If no teleport region is specified, the device will be in the default region (New York, USA).

A list of available teleport regions can be found by requesting the teleport regions API endpoint with your API key:

curl -H 'Authorization: Bearer <api_key>' https://tvlabs.ai/api/v1/teleport/regions
{"data": [...]}
note

If you don't have an API key, you can create one on the API Keys page.

tvlabs:match_timeout (optional)

The tvlabs:match_timeout capability defines the maximum time (in seconds) to wait for a device matching your tvlabs:constraints. If no device is found within this timeout, the session fails with a 400 response code. Set this value lower for fast failures or higher to allow more matching time. The default is 300 seconds (5 minutes) when making a request through the TV Labs Appium proxy endpoint, or 900 seconds (15 minutes) when making a request through the TV Labs WebDriverIO service.

tvlabs:device_timeout (optional)

The tvlabs:device_timeout capability defines the maximum time (in seconds) to wait for a matched device to become ready. If the device isn't ready within this timeout, the session fails with a 400 response code. The default is 60 seconds, which should be sufficient for most use cases.

warning

Many webdriver clients have client-side configuration for timeouts, for example, webdriverio provides a connectionRetryTimeout configuration option that defaults to 2 minutes. If this value is set too low, the request may timeout before the TV Labs device has been matched to the request, or before the device has had time to warm up. To avoid this, configure your webdriver client request timeout to be greater than the sum of tvlabs:match_timeout and tvlabs:device_timeout capabilities.

tvlabs:licensing_timeout (optional)

The tvlabs:licensing_timeout capability defines the maximum time (in seconds) to wait for a license to become available. If no license is available within this timeout, the session fails with a 400 response code. The default value is 300 seconds (5 minutes).

tvlabs:session_id (optional)

If a TV Labs session has already been created, the tvlabs:session_id capability can be provided to skip TV Labs session creation on the WebDriver New Session command. This is used by the @tvlabs/wdio-service WebdriverIO service to provide a pre-created session, and is not normally provided by the end user.

tvlabs:log_network (optional)

The tvlabs:log_network capability enables network logging for the Appium session. See the Network Capture page for more information.

Versions

The TV Labs platform currently runs Appium Server 2.19.0.

For specific driver versions, see the Platforms section below.

Platforms

The following platforms are supported by the TV Labs Appium proxy:

Platformplatform_keyplatform_os_variantAppium DriverDriver VersionDevice TypesSupports InspectorBuild Format
Rokuroku-appium-roku-driver2.7.0Television, Set-Top BoxYes.zip
WebOS (LG)web_os-appium-lg-webos-driver0.5.2TelevisionNo.ipk
Tizen TV (Samsung)tizen-appium-tizen-tv-driver0.18.2TelevisionYes.wgt
Apple TVtv_os-appium-xcuitest-driver9.9.1Set-Top BoxYes.ipa
iOS (any)ios-appium-xcuitest-driver9.9.1Tablet, PhoneYes.ipa
iPhoneiosiphone_osappium-xcuitest-driver9.9.1PhoneYes.ipa
iPadiosipad_osappium-xcuitest-driver9.9.1TabletYes.ipa
SmartCast (Vizio)smartcast-appium-smartcast-driver1.0.3TelevisionYes.zip
Android Mobile (any)android_mobile-appium-uiautomator2-driver4.2.4Tablet, PhoneYes.apk
Galaxy Phoneandroid_mobilegalaxyappium-uiautomator2-driver4.2.4PhoneYes.apk
Pixel Phoneandroid_mobilepixelappium-uiautomator2-driver4.2.4PhoneYes.apk
Fire Tabletandroid_mobilefireappium-uiautomator2-driver4.2.4TabletYes.apk
Android TV (any)android_tv-appium-uiautomator2-driver4.2.4Television, Set-Top BoxYes.apk
Stock Android TVandroid_tvstockappium-uiautomator2-driver4.2.4Television, Set-Top BoxYes.apk
Google TVandroid_tvgoogle_tvappium-uiautomator2-driver4.2.4Television, Set-Top BoxYes.apk
Fire TVandroid_tvfire_tvappium-uiautomator2-driver4.2.4Television, Set-Top BoxYes.apk

When uploading a build to be used with Appium via the tvlabs upload command, the build will need to be in an expected format for the platform. Please view the documentation provided by each platform to see how to prepare the build.

important

On platforms where the application package needs to be signed, uploaded application packages will be re-signed using TV Labs certificates before sideloading. It is not necessary to sign the package before uploading.

ChromeDrivers

For Appium drivers that use ChromeDriver to perform automation on the device, the ChromeDriver will be automatically selected based on the version of Chromium browser that is running on the device.

The version of ChromeDriver configured for a device may not always be an exact match to the version of Chromium browser running on the television if there is not a build available, but the closest compatible version will be selected.

Some devices do not support ChromeDriver, and the use of Appium automation features will be limited, see the specific drivers documentation for more information.

Use the chromedriver_version field in your constraint query to ensure that a target device is compatible with ChromeDriver. Read more about writing constraint queries in the device targeting documentation.

QueryDescription
chromedriver_version:*Match any device with a ChromeDriver version
chromedriver_version>=120.0.0.0Match any device with a ChromeDriver version 120.0.0.0 or higher
chromedriver_version:120.*Match any device with a ChromeDriver that has major version 120

Screenshots

On the TV Labs platform, Appium screenshots are not captured using the underlying driver. Instead, the screenshot request is intercepted and uses the device video capture to grab a screenshot. What this means in practice is that Appium users are able to capture screenshots on any device using any driver, regardless of whether or not the driver supports it.

One example of how this is useful: on Roku the driver can only capture the screen when a sideloaded development application is running. This is a limitation of the underlying ECP protocol that the Roku Appium driver uses. However, on the TV Labs platform, you can capture screenshots outside the development app as well.

Response Headers

The TV Labs Appium proxy includes custom response headers that provide additional metadata about the session and video recordings.

Video Timing Headers

All Appium responses include the following headers that indicate the video timing for the request:

  • x-video-start-time: The video timestamp (in milliseconds) when the request was received
  • x-video-end-time: The video timestamp (in milliseconds) when the response was sent

These headers can be used to correlate Appium commands with specific moments in the session video recording, which is particularly useful for debugging and analysis.

note

To access these headers, you will need to intercept them from your HTTP client.

WebdriverIO Service

To better support the use case of running Appium tests on the TV Labs platform with the WebdriverIO framework, we have created the @tvlabs/wdio-service WebdriverIO service package.

The @tvlabs/wdio-service package uses a websocket to connect to the TV Labs platform before an Appium session begins, logging events relating to TV Labs session creation as they occur. This offloads the responsibility of creating the TV Labs session from the POST /session Webdriver endpoint, leading to more reliable session requests and creation. Additionally, the service supports build uploads and provides better logging in the form of request ID tracing.

To use @tvlabs/wdio-service, install the package with npm install @tvlabs/wdio-service or your favorite package manager, and add it to your WebdriverIO test runner configuration.

// wdio.conf.js
export const config = {
// ...
services: [
[
TVLabsService,
{
apiKey: process.env.TVLABS_API_KEY,
buildPath: process.env.TVLABS_BUILD_PATH,
},
],
],
// ...
};

The service can be used with the remote API as well, see the package README and example for more information.

Once the service is installed, you can observe logs in the test runner output relating to the TV Labs session creation process before your Appium test script begins.

[0-0] 2025-03-28T17:15:44.459Z INFO wdio-tvlabs-service: Requesting TV Labs session
[0-0] 2025-03-28T17:15:45.461Z INFO wdio-tvlabs-service: Received session request ID: 534465. Waiting for a match...
[0-0] 2025-03-28T17:15:45.872Z INFO wdio-tvlabs-service: Session request 534465 matching...
[0-0] 2025-03-28T17:15:45.873Z INFO wdio-tvlabs-service: Session request 534465 filled: https://tvlabs.ai/app/sessions/b936e307-8280-4949-8d13-ac0da83b1f5e
[0-0] 2025-03-28T17:15:45.874Z INFO wdio-tvlabs-service: Waiting for device to be ready...
[0-0] 2025-03-28T17:15:52.301Z INFO wdio-tvlabs-service: Session b936e307-8280-4949-8d13-ac0da83b1f5e ready!