
Security News
OWASP 2025 Top 10 Adds Software Supply Chain Failures, Ranked Top Community Concern
OWASP’s 2025 Top 10 introduces Software Supply Chain Failures as a new category, reflecting rising concern over dependency and build system risks.
@wdio/browserstack-service
Advanced tools
A WebdriverIO service that manages local tunnel and job metadata for BrowserStack users.
The easiest way is to keep @wdio/browserstack-service as a devDependency in your package.json, via:
npm install @wdio/browserstack-service --save-dev
Instructions on how to install WebdriverIO can be found here.
WebdriverIO has BrowserStack support out of the box. You should set user and key in your wdio.conf.js file. This service plugin provides support for BrowserStack Tunnel. Set browserstackLocal: true also to activate this feature.
Reporting of session status on BrowserStack will respect strict setting of Cucumber options.
// wdio.conf.js
export const config = {
// ...
user: process.env.BROWSERSTACK_USERNAME,
key: process.env.BROWSERSTACK_ACCESS_KEY,
services: [
['browserstack', {
testReporting: true,
testReportingOptions: {
projectName: "Your project name goes here",
buildName: "The static build job name goes here e.g. Nightly regression"
},
browserstackLocal: true
}]
],
// ...
};
In order to authorize to the BrowserStack service your config needs to contain a user and key option.
Test Reporting and Analytics is an advanced test reporting tool that gives insights to improve your automation tests and helps you debug faster. It's enabled by default by setting the testReporting flag as true for all users of browserstack-service. You can disable this by setting the testReporting flag to false.
Once your tests finish running, you can visit Test Reporting and Analytics to debug your builds with additional insights like Unique Error Analysis, Automatic Flaky Test Detection, and more.
You can use Test Reporting and Analytics even if you don't run your tests on the BrowserStack infrastructure. Even if you run your tests on a CI, a local machine, or even on other cloud service providers, Test Reporting and Analytics can still generate intelligent test reports and advanced analytics on your tests.
If you want to use Test Reporting and Analytics without running your tests on BrowserStack infrastructure, you can set your config as follows:
// wdio.conf.js
export const config = {
// ...
services: [
['browserstack', {
testReporting: true,
testReportingOptions: {
user: process.env.BROWSERSTACK_USERNAME,
key: process.env.BROWSERSTACK_ACCESS_KEY,
projectName: "Your project name goes here",
buildName: "The static build job name goes here e.g. Nightly regression"
}
}]
],
// ...
};
For backward compatibility, the legacy testObservability and testObservabilityOptions flags are still supported:
// wdio.conf.js (legacy configuration)
export const config = {
// ...
services: [
['browserstack', {
testObservability: true, // deprecated, use testReporting instead
testObservabilityOptions: { // deprecated, use testReportingOptions instead
user: process.env.BROWSERSTACK_USERNAME,
key: process.env.BROWSERSTACK_ACCESS_KEY,
projectName: "Your project name goes here",
buildName: "The static build job name goes here e.g. Nightly regression"
}
}]
],
// ...
};
The following environment variables are supported:
New (recommended):
BROWSERSTACK_TEST_REPORTING - Enable/disable test reportingBROWSERSTACK_TEST_REPORTING_DEBUG - Enable debug mode for test reportingTEST_REPORTING_BUILD_TAG - Comma-separated build tagsLegacy (still supported):
BROWSERSTACK_OBSERVABILITY - Enable/disable test observability (deprecated)TEST_OBSERVABILITY_BUILD_TAG - Comma-separated build tags (deprecated)You can explore all the features of Test Reporting and Analytics in this sandbox or read more about it here.
Set this to true to enable routing connections from BrowserStack cloud through your computer.
Type: Boolean
Default: false
Set this to true to kill the BrowserStack Local process on complete, without waiting for the BrowserStack Local stop callback to be called. This is experimental and should not be used by all. Mostly necessary as a workaround for this issue.
Type: Boolean
Default: false
Appium set this with the app file path available locally on your machine to use the app as application under test for Appium sessions.
Type: String or JsonObject
Default: undefined
List of available app values:
Use locally available app file path as an application under test for Appium.
services: [
['browserstack', {
app: '/path/to/local/app.apk'
// OR
app: {
path: '/path/to/local/app.apk'
}
}]
]
Pass custom_id while the app upload.
services: [
['browserstack', {
app: {
path: '/path/to/local/app.apk',
custom_id: 'custom_id'
}
}]
]
Use the app URL returned after uploading the app to BrowserStack.
services: [
['browserstack', {
app: 'bs://<app-id>'
// OR
app: {
id: 'bs://<app-id>'
}
}]
]
use custom_id of already uploaded apps
services: [
['browserstack', {
app: 'custom_id'
// OR
app: {
custom_id: 'custom_id'
}
}]
]
use shareable_id of already uploaded apps
services: [
['browserstack', {
app: 'username/custom_id'
// OR
app: {
shareable_id: 'username/custom_id'
}
}]
]
Cucumber only. Set the BrowserStack Automate session name to the Scenario name if only a single Scenario ran. Useful when running in parallel with wdio-cucumber-parallel-execution.
Type: Boolean
Default: false
Customize the BrowserStack Automate session name format.
Type: Function
Default (Cucumber/Jasmine): (config, capabilities, suiteTitle) => suiteTitle
Default (Mocha): (config, capabilities, suiteTitle, testTitle) => suiteTitle + ' - ' + testTitle
Mocha only. Do not append the test title to the BrowserStack Automate session name.
Type: Boolean
Default: false
Mocha only. Prepend the top level suite title to the BrowserStack Automate session name.
Type: Boolean
Default: false
Automatically set the BrowserStack Automate session name.
Type: Boolean
Default: true
Automatically set the BrowserStack Automate session status (passed/failed).
Type: Boolean
Default: true
buildIdentifier is a unique id to differentiate every execution that gets appended to buildName. Choose your buildIdentifier format from the available expressions:
BUILD_NUMBER: Generates an incremental counter with every executionDATE_TIME: Generates a Timestamp with every execution. Eg. 05-Nov-19:30services: [
['browserstack', {
buildIdentifier: '#${BUILD_NUMBER}'
}]
]
Build Identifier supports usage of either or both expressions along with any other characters enabling custom formatting options.
BrowserStack Local options.
Type: Object
Default: {}
List of available local testing modifiers to be passed as opts:
If doing simultaneous multiple local testing connections, set this uniquely for different processes -
opts = { localIdentifier: "randomstring" };
To enable verbose logging -
opts = { verbose: "true" };
Note - Possible values for 'verbose' modifier are '1', '2', '3' and 'true'
To route all traffic via local(your) machine -
opts = { forceLocal: "true" };
To test local folder rather internal server, provide path to folder as value of this option -
opts = { f: "/my/awesome/folder" };
To kill other running BrowserStack Local instances -
opts = { force: "true" };
To disable local testing for Live and Screenshots, and enable only Automate -
opts = { onlyAutomate: "true" };
To use a proxy for local testing -
opts = {
proxyHost: "127.0.0.1",
proxyPort: "8000",
proxyUser: "user",
proxyPass: "password",
};
To use local proxy in local testing -
opts = {
localProxyHost: "127.0.0.1",
localProxyPort: "8000",
localProxyUser: "user",
localProxyPass: "password",
};
To use PAC (Proxy Auto-Configuration) in local testing -
opts = { "pac-file": "<pac_file_abs_path>" };
By default, BrowserStack local wrappers try downloading and executing the latest version of BrowserStack binary in ~/.browserstack or the present working directory or the tmp folder by order. But you can override these by passing the -binarypath argument. Path to specify local Binary path -
opts = { binarypath: "/path/to/binary" };
To save the logs to the file while running with the '-v' argument, you can specify the path of the file. By default the logs are saved in the local.log file in the present woring directory. To specify the path to file where the logs will be saved -
opts = { verbose: "true", logFile: "./local.log" };
For more information on WebdriverIO see the homepage.
@wdio/sauce-service is a WebdriverIO service that provides integration with Sauce Labs, another cloud-based cross-browser testing platform. Similar to @wdio/browserstack-service, it allows you to run your WebdriverIO tests on Sauce Labs' infrastructure, offering features like parallel testing and automated screenshots.
WebdriverIO is a popular testing framework for Node.js that allows you to run tests on various browsers and devices. While it does not provide direct integration with BrowserStack or Sauce Labs, it can be extended with services like @wdio/browserstack-service and @wdio/sauce-service to achieve similar functionalities.
Nightwatch is an end-to-end testing framework that supports running tests on various browsers and devices. It offers built-in support for BrowserStack and Sauce Labs, making it a viable alternative to using WebdriverIO with @wdio/browserstack-service.
FAQs
WebdriverIO service for better Browserstack integration
The npm package @wdio/browserstack-service receives a total of 238,283 weekly downloads. As such, @wdio/browserstack-service popularity was classified as popular.
We found that @wdio/browserstack-service demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
OWASP’s 2025 Top 10 introduces Software Supply Chain Failures as a new category, reflecting rising concern over dependency and build system risks.

Research
/Security News
Socket researchers discovered nine malicious NuGet packages that use time-delayed payloads to crash applications and corrupt industrial control systems.

Security News
Socket CTO Ahmad Nassri discusses why supply chain attacks now target developer machines and what AI means for the future of enterprise security.