Socket
Socket
Sign inDemoInstall

browserstack-cypress-cli

Package Overview
Dependencies
Maintainers
1
Versions
73
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

browserstack-cypress-cli

BrowserStack Cypress CLI for Cypress integration with BrowserStack's remote devices.


Version published
Weekly downloads
44K
increased by19.18%
Maintainers
1
Weekly downloads
 
Created
Source

BrowserStack Cypress CLI

You can now run your Cypress tests in BrowserStack using our browserstack-cypress-cli. BrowserStack currently supports Cypress 4 and you can start testing on the following browser combinations:

Windows 10OS X MojaveOS X Catalina
Chrome 66.0 to 79.0Chrome 66.0 to 79.0Chrome 66.0 to 79.0
Edge 80.0Edge 80.0Edge 80.0
Firefox 60.0 to 72.0Firefox 60.0 to 72.0Firefox 60.0 to 72.0

We are actively working on supporting other browsers and will start adding other browsers to this list.

Using BrowserStack-Cypress CLI:

Installing browserstack-cypress

# Install cypress (ignore if already done)
$ npm install -g cypress@4.0.2

# Install the BrowserStack Cypress CLI
$ npm install -g browserstack-cypress-cli

Configuring your tests

# create a sample configuration file for configurations and capabilities
$ browserstack-cypress init

This will create a sample browserstack.json file. This file can be used to configure your test runs on BrowserStack. Below is the sample file that is generated for your reference.

{
    "auth": {
      "username": "<your-browserstack-username>",
      "access_key": "<your-browserstack-access-key>"
    },
    "browsers": [
      {
        "browser": "chrome",
        "os": "OS X Catalina",
        "versions": ["69","66"]
      }
    ],
    "run_settings": {
      "cypress_proj_dir": "/path/to/directory-that-contains-<cypress.json>-file",
      "project": "my first project",
      "customBuildName": "build 1"
    },
    "connection_settings": {
      "local": false
    }
}

The following table provides a reference for all the options that can be provided in browserstack.json shown above.

OptionDescriptionPossible values
usernameThis is your BrowserStack username. You can find this in your Automate dashboard-
access_keyThis is your BrowserStack access key. You can find this in your Automate dashboard-
os
(case-sensitive)
The operating system on which you want to run your test.OS X Mojave,
OS X Catalina, and
Windows 10
browser
(case-sensitive)
The browser on which you want to run your tests.chrome,
firefox, and
edge
versionsA list of browser versions that you want to run your tests on.

Example: To run on versions 69, 67 and 65 provide ["69", "67", "65"]
Right now edge 80 and all chrome versions from 66 to 78 are supported
specs
(deprecated)
This param is deprecated in favour of a more complete cypress_proj_dir param. The path to the spec files that need to be run on BrowserStackTakes a list of strings that point to location of the spec files
cypress_proj_dirPath to the folder which contains cypress.json file. This path will be considered as the root path of the project.-
projectName of your project. This will be displayed in your Automate dashboard, and you'll be able to search & filter your tests based on the project name.A string providing the name of the project
customBuildNameHelps in providing a custom name for the build. This will be displayed in your Automate dashboard, and you'll be able to search & filter your tests based on the build name.A string providing the name of the build
localHelps in testing websites that cannot be accessed in public network. If you set this to true, please download the Local binary and establish a local connection first (you can learn how to do so here)Boolean: true / false. Set this to true if you need to test a local website. Set this to false if the website is accessible publicly.

Running the tests

You can start running your test build using the following command.

$ browserstack-cypress run

Sample output :

[2/20/2020, 2:58:31 PM]  Reading browserstack.json from /browserstack.json
[2/20/2020, 2:58:31 PM]  browserstack.json file is validated
[2/20/2020, 2:58:31 PM]  Adding  tests/*.js to zip
[2/20/2020, 2:58:34 PM]  Zip uploaded with url: bs://15f90b540b8cbc47929782f35bb7db20fe1c4709
[2/20/2020, 2:58:34 PM]  File deleted successfully
[2/20/2020, 2:58:34 PM]  Browser list: OS X Catalina-chrome69,OS X Catalina-chrome66
[2/20/2020, 2:58:34 PM]  Test suite: bs://15f90b540b8cbc47929782f35bb7db20fe1c4709
[2/20/2020, 2:58:34 PM]  Local is set to: false
[2/20/2020, 2:58:34 PM]  Build name is: cypress build
[2/20/2020, 2:58:34 PM]  Success
[2/20/2020, 2:58:36 PM]  Build created with build id: 06f28ce423d10314b32e98bb6f68e10b0d02a49a
[2/20/2020, 2:58:36 PM]  File deleted successfully.

Getting build information

In case you want to get information on the build you can use the following command

browserstack-cypress build-info <buildId>

Example

browserstack-cypress build-info 06f28ce423d10314b32e98bb6f68e10b0d02a49a

Output:

[2/20/2020, 3:01:52 PM]  Getting information for buildId 06f28ce423d10314b32e98bb6f68e10b0d02a49a
[2/20/2020, 3:01:52 PM]  Reading browserstack.json from /browserstack.json
[2/20/2020, 3:01:54 PM]  Build info for build id:
 {
  "build_id": "06f28ce423d10314b32e98bb6f68e10b0d02a49a",
  "framework": "cypress",
  "status": "done",
  "input_capabilities": {
    "devices": [
      "OS X Catalina-chrome69",
      "OS X Catalina-chrome66"
    ],
    "testSuite": "15f90b540b8cbc47929782f35bb7db20fe1c4709",
    "customBuildName": "cypress build",
    "local": false,
    "localIdentifier": null,
    "callbackURL": null,
    "projectNotifyURL": null,
    "project": "test"
  },
  "start_time": "2020-02-20 09:28:35 UTC",
  "device_statuses": {
    "success": {
      "OS X Catalina-chrome69": "Success",
      "OS X Catalina-chrome66": "Success"
    },
    "error": {}
  },
  "test_suite_details": {
    "url": "bs://15f90b540b8cbc47929782f35bb7db20fe1c4709",
    "name": "tests.zip",
    "size": 354
  },
  "duration": "33 seconds",
  "devices": {
    "OS X Catalina-chrome69": {
      "session_id": "3b4038cbbc55d34c1b33c930f3417c7c534c25dd",
      "status": "done",
      "test_status": {
        "failed": 0,
        "success": 3,
        "queued": 0,
        "ignored": 0
      }
    },
    "OS X Catalina-chrome66": {
      "session_id": "fbda8eb5a9eeb7823a9ef7be1a42213c568197e8",
      "status": "done",
      "test_status": {
        "failed": 0,
        "success": 3,
        "queued": 0,
        "ignored": 0
      }
    }
  }
}

Note: Each browser version represents a session. It is advised to validate your account's parallel limit before running multiple versions.

Stopping a running build

In case you want to stop a running build, you can use the following command

browserstack-cypress build-stop <buildId>

Example

browserstack-cypress build-stop 06f28ce423d10314b32e98bb6f68e10b0d02a49a

Output:

[3/24/2020, 2:31:11 PM]  Stopping build with given buildId 06f28ce423d10314b32e98bb6f68e10b0d02a49a
[3/24/2020, 2:31:12 PM]  Reading config from /browserstack.json
[3/24/2020, 2:31:14 PM]  {
  "message": "stopped 1 sessions",
  "stopped_session_count": 1
}

Limitations

  • exec and task are not allowed.
  • While using local, please make sure to create /etc/hosts entry pointing to some URL, and use that URL in the tests. The localhost URI doesn't work at the moment.
  • Installing custom npm packages are not supported at this moment.

Accessing test results

You can access your test results in BrowserStack Automate dashboard. The dashboard provides test details along with video, console logs and screenshots to help you debug any issues.

License

This project is released under MIT License. Please refer the LICENSE.md for more details.

FAQs

Package last updated on 08 Apr 2020

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc