Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/saucelabs/node-saucelabs
A wrapper around Sauce Labs API
https://github.com/saucelabs/node-saucelabs
api api-client hacktoberfest rest sauce-connect sauce-labs saucelabs
Last synced: 5 days ago
JSON representation
A wrapper around Sauce Labs API
- Host: GitHub
- URL: https://github.com/saucelabs/node-saucelabs
- Owner: saucelabs
- License: apache-2.0
- Created: 2012-06-01T11:43:00.000Z (over 12 years ago)
- Default Branch: main
- Last Pushed: 2024-10-21T18:05:54.000Z (2 months ago)
- Last Synced: 2024-10-29T17:44:05.762Z (2 months ago)
- Topics: api, api-client, hacktoberfest, rest, sauce-connect, sauce-labs, saucelabs
- Language: JavaScript
- Homepage:
- Size: 2.68 MB
- Stars: 93
- Watchers: 16
- Forks: 44
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Node Sauce Labs [![Test Changes](https://github.com/saucelabs/node-saucelabs/actions/workflows/test.yml/badge.svg)](https://github.com/saucelabs/node-saucelabs/actions/workflows/test.yml)
Wrapper around all Sauce Labs REST APIs for [Node.js](http://nodejs.org/) (v18 or higher) including support for
[Sauce Connect Proxy](https://docs.saucelabs.com/secure-connections/sauce-connect/) and TypeScript definitions.## Install
To install the package run:
```sh
npm install saucelabs
```## Options
### user
Your Sauce Labs username.
Type: `string`
Default: `process.env.SAUCE_USERNAME`### key
Your Sauce Labs access key.
Type: `string`
Default: `process.env.SAUCE_ACCESS_KEY`### region
Your Sauce Labs datacenter region. The following regions are available:
- `us-west-1` (short `us`)
- `eu-central-1` (short `eu`)
- `us-east-4` (real mobile devices only)Type: `string`
Default: `us`### proxy
If you want to tunnel your API request through a proxy please provide your proxy URL.
Type: `string`
Default: `null`### headers
If you want to set request headers, as example {'User-Agent': 'node-saucelabs'}
Type: `object`
Default: `{'User-Agent': 'saucelabs/ (nodejs )'}`## Usage
All accessible API commands with descriptions can be found [here](docs/interface.md).
### As CLI Tool
This package if installed globally can be used as CLI tool to access the API from the command line:
```sh
$ npm install -g saucelabs
...
$ sl listJobs $SAUCE_USERNAME 5 --region eu
{ jobs:
[ { id: '19dab74f8fd848518f8d2c2cee3a6fbd' },
{ id: 'dc08ca0c7fa14eee909a093d11567328' },
{ id: '5bc6f70c777b4ae3bf7909a40f5ee41b' },
{ id: 'f40fe7b044754eaaa5f5a130406549b5' },
{ id: 'd1553f71f910402893f1e82a4dcb6ca6' } ] }
```You can find all available commands and options with description by calling:
```sh
$ sl --help
# show description for specific command
$ sl listJobs --help
```or update the job status by calling:
```sh
$ sl updateJob cb-onboarding 690c5877710c422d8be4c622b40c747f "{\"passed\":false}"
```or download a job asset:
```sh
$ sl downloadJobAsset 690c5877710c422d8be4c622b40c747f video.mp4 --filepath ./video.mp4
```or upload a job asset:
```sh
$ sl uploadJobAssets 690c5877710c422d8be4c622b40c747f --files ./video.mp4 --files ./log.json
```or start Sauce Connect Proxy in EU datacenter:
```sh
# start Sauce Connect tunnel for eu-central-1 region
$ sl sc --region eu --tunnel-name "my-tunnel"
# run a specific Sauce Connect version
$ sl sc --scVersion 4.9.1
# see all available Sauce Connect parameters via:
$ sl sc --help
```You can see all available Sauce Connect parameters on the [Sauce Labs Docs](https://docs.saucelabs.com/dev/cli/sauce-connect-proxy/).
### As NPM Package
The following example shows how to access details of the last job you were running with your account that is being exposed as environment variables as `SAUCE_USERNAME` and `SAUCE_ACCESS_KEY`. Alternatively you can pass the credentials via `options` to the constructor:
```js
import SauceLabs from 'saucelabs';
// if imports are not supported by your Node.js version, import the package as follows:
// const SauceLabs = require('saucelabs').default;(async () => {
const myAccount = new SauceLabs();
// using constructor options
// const myAccount = new SauceLabs({ user: "YOUR-USER", key: "YOUR-ACCESS-KEY"});// get full webdriver url from the client depending on region:
console.log(myAccount.webdriverEndpoint); // outputs "https://ondemand.us-west-1.saucelabs.com/"// get job details of last run job
const jobs = await myAccount.listJobs(process.env.SAUCE_USERNAME, {
limit: 1,
full: true,
});console.log(jobs);
/**
* outputs:
* { jobs:
[ { browser_short_version: '72',
video_url:
'https://assets.saucelabs.com/jobs/dc08ca0c7fa14eee909a093d11567328/video.flv',
creation_time: 1551711453,
'custom-data': null,
browser_version: '72.0.3626.81',
owner: '',
id: 'dc08ca0c7fa14eee909a093d11567328',
record_screenshots: true,
record_video: true,
build: null,
passed: null,
public: 'team',
end_time: 1551711471,
status: 'complete',
log_url:
'https://assets.saucelabs.com/jobs/dc08ca0c7fa14eee909a093d11567328/selenium-server.log',
start_time: 1551711454,
proxied: false,
modification_time: 1551711471,
tags: [],
name: null,
commands_not_successful: 1,
consolidated_status: 'complete',
manual: false,
assigned_tunnel_id: null,
error: null,
os: 'Windows 2008',
breakpointed: null,
browser: 'googlechrome' } ] }
*//**
* start Sauce Connect Proxy
*/
const sc = await myAccount.startSauceConnect({
/**
* you can pass in a `logger` method to print Sauce Connect log messages
*/
logger: (stdout) => console.log(stdout),
/**
* see all available parameters here: https://docs.saucelabs.com/dev/cli/sauce-connect-proxy/
* all parameters have to be applied camel cased instead of with hyphens, e.g.
* to apply the `--tunnel-name` parameter, set:
*/
tunnelName: 'my-tunnel',
});// run a test
// ...// close Sauce Connect
await sc.close();// upload additional log files and attach it to your Sauce job
await myAccount.uploadJobAssets('76e693dbe6ff4910abb0bc3d752a971e', [
// either pass in file names
'./logs/video.mp4',
'./logs/log.json',
// or file objects
{
filename: 'myCustomLogFile.json',
data: {
someLog: 'data',
},
},
]);
})();
```> You may wonder why `listJobs` requires a `username` as first parameter since you've already defined the process.env. The reason for this is that Sauce Labs supports a concept of Team Accounts, so-called sub-accounts, grouped together. As such functions like the mentioned could list jobs not only for the requesting account, but also for the individual team account. Learn more about it [here](https://docs.saucelabs.com/basics/acct-team-mgmt-hub/)
### `webdriverEndpoint` property
You can use the `webdriverEndpoint` property of the client to get the full WebDriver endpoint to connect to Sauce Labs, e.g.:
```js
const myAccount = new SauceLabs({
user: 'YOUR-USER',
key: 'YOUR-ACCESS-KEY',
region: 'eu', // run in EU datacenter
});// get full webdriver url from the client depending on `region` option:
console.log(myAccount.webdriverEndpoint);
// outputs: "https://ondemand.eu-central-1.saucelabs.com/"
```## Contributors
This module was originally created by [Dan Jenkins](https://github.com/danjenkins) with the help of multiple contributors ([Daniel Perez Alvarez](https://github.com/unindented), [Mathieu Sabourin](https://github.com/OniOni), [Michael J Feher](https://github.com/PhearZero), and many more). We would like to thank Dan and all contributors for their support and this beautiful module.
## License
Copyright 2012 Sauce Labs, Inc. Licensed Apache-2.0