Skip to main content
Transform your testing process with: Real Device Features, Company-wide Licences, & Test Observability

Run Jest Playwright tests

Get started with running Jest Playwright tests on BrowserStack Automate across 100+ browser/OS combinations

Running your first Jest Playwright test suite on BrowserStack is super easy. Here’s a quick start guide to help you get started with Playwright testing on BrowserStack in under 2 minutes.

Step 1: Clone our sample repository and install dependencies (if not already done)

All our sample tests are available on this GitHub repository. The first step is to download this repository on your system and install the dependencies as shown below:

Command Line
# The following command will clone the repository on your system

git clone https://github.com/browserstack/playwright-browserstack.git
cd playwright-browserstack/playwright-jest
npm install

Step 2: Configuring BrowserStack credentials

Testing on BrowserStack requires username and access key that can be found in account settings.
If you have not created an account yet, you can sign up for a Free Trial or purchase a plan.

All our sample scripts need your BrowserStack credentials to run. Please set the environment variables BROWSERSTACK_USERNAME and BROWSERSTACK_ACCESS_KEY with your credentials as shown below:

Command Line
export BROWSERSTACK_USERNAME="YOUR_USERNAME"
export BROWSERSTACK_ACCESS_KEY="YOUR_ACCESS_KEY"

Alternatively, your can put your credentials in the browserstack.username and browserstack.accessKey capabilities in the jest-playwright.config.js file in the sample repository.

Step 3: Run your Jest Playwright test

After you have configured the credentials and installed the npm dependencies, you can invoke your first Jest Playwright test on BrowserStack using the following (you have to ensure that jest is installed as a global npm package):

Command Line
jest

After the test has run, you can access the test results on the BrowserStack Automate dashboard.

Run your existing Jest Playwright suite on BrowserStack

If you have an existing Jest Playwright test suite, then you can make a few quick modifications to the jest-playwright.conf.js file as shown below and make your suite run on BrowserStack:

jest-playwright.conf.js
const cp = require('child_process');
const clientPlaywrightVersion = cp.execSync('npx playwright --version').toString().trim().split(' ')[1];

const caps_chromium = {
  'browser': 'playwright-chromium', // allowed browsers are `chrome`, `edge`, `playwright-chromium`, `playwright-firefox` and `playwright-webkit`
  'os': 'osx',
  'os_version': 'big sur',
  'name': 'Playwright-jest test on Chromium',
  'build': 'playwright-jest-build-1',
  'browserstack.username': 'YOUR_USERNAME',
  'browserstack.accessKey': 'YOUR_ACCESS_KEY',
  'client.playwrightVersion': clientPlaywrightVersion
};

const caps_firefox = {
  'browser': 'playwright-firefox', // allowed browsers are `chrome`, `edge`, `playwright-chromium`, `playwright-firefox` and `playwright-webkit`
  'os': 'osx',
  'os_version': 'big sur',
  'name': 'Playwright-jest test on Firefox',
  'build': 'playwright-jest-build-1',
  'browserstack.username': 'YOUR_USERNAME',
  'browserstack.accessKey': 'YOUR_ACCESS_KEY',
  'client.playwrightVersion': clientPlaywrightVersion
};

const caps_webkit = {
  'browser': 'playwright-webkit', // allowed browsers are `chrome`, `edge`, `playwright-chromium`, `playwright-firefox` and `playwright-webkit`
  'os': 'osx',
  'os_version': 'big sur',
  'name': 'Playwright-jest test on Webkit',
  'build': 'playwright-jest-build-1',
  'browserstack.username': process.env.BROWSERSTACK_USERNAME || 'YOUR_USERNAME',
  'browserstack.accessKey': process.env.BROWSERSTACK_ACCESS_KEY || 'YOUR_ACCESS_KEY',
  'client.playwrightVersion': clientPlaywrightVersion
};

module.exports = {
  connectOptions: {
    chromium: {
      wsEndpoint: `wss://cdp.browserstack.com/playwright?caps=${encodeURIComponent(JSON.stringify(caps_chromium))}`
    },
    firefox: {
      wsEndpoint: `wss://cdp.browserstack.com/playwright?caps=${encodeURIComponent(JSON.stringify(caps_firefox))}`
    },
    webkit: {
        wsEndpoint: `wss://cdp.browserstack.com/playwright?caps=${encodeURIComponent(JSON.stringify(caps_webkit))}`
    }
  },
  browsers: ['chromium', 'firefox', 'webkit'],
}

Playwright tests run on BrowserStack using a client-server architecture. So, test assertions run on the client side and hence BrowserStack won’t know whether your tests have passed or failed. Learn more how to mark tests as passed or failed on BrowserStack.

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