TV Labs Service
@tvlabs/wdio-service is a 3rd party package, for more information please see GitHub | npm
@tvlabs/wdio-service is a WebdriverIO service for seamless integration with the TV Labs platform.
Introduction
The @tvlabs/wdio-service
package uses a websocket to connect to the TV Labs platform before an Appium session begins, logging events relating to build upload and 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.
If a build path is provided, the service first makes a build upload request to the TV Labs platform, and then sets the tvlabs:build
capability to the newly created build ID.
The service then makes a session request and then subscribes to events for that request. Once the session has been filled and is ready for the Webdriver script to begin, the service receives a ready event with the TV Labs session ID. This session ID is injected into the capabilities as tvlabs:session_id
on the Webdriver session create request.
Additionally, the service adds a unique request ID for each request made. The service will generate and attach an x-request-id
header before each request to the TV Labs platform. This can be used to correlate requests in the client side logs to the Appium server logs.
Installation
In your WebdriverIO project, run one of the following commands to install:
NPM
npm i --save @tvlabs/wdio-service
Yarn
yarn add @tvlabs/wdio-service
Usage
WebdriverIO Test Runner
To use this as a WebdriverIO test runner service, include the service in your WebdriverIO configuration file (e.g. wdio.conf.ts
) with your TV Labs API key set in the options.
import { TVLabsService } from '@tvlabs/wdio-service';
export const config = {
// ...
services: [[TVLabsService, { apiKey: process.env.TVLABS_API_KEY }]],
// ...
};