GithubHelp home page GithubHelp logo

isabella232 / testswarm-browserstack Goto Github PK

View Code? Open in Web Editor NEW

This project forked from jquery/testswarm-browserstack

0.0 0.0 0.0 134 KB

Integration layer between TestSwarm and BrowserStack

License: MIT License

Shell 1.58% JavaScript 98.42%

testswarm-browserstack's Introduction

Build Status npm

testswarm-browserstack

This is a lightweight integration layer between TestSwarm and BrowserStack. Use it to spawn BrowserStack workers needed by TestSwarm on demand. It uses node-browserstack to abstract the BrowserStack API.

This script is currently compatible with:

Install


git clone https://github.com/clarkbox/testswarm-browserstack.git testswarm-browserstack
cd testswarm-browserstack/
npm install

How to use CLI:


node src/cli.js --run

This above command will create and terminate BrowserStack workers as needed according to the information the TestSwarm swarmstate API provides. This command should be executed on a regular interval, either via a scheduler (such as crontab) or by letting node do a continuous loop (using the --run-loop option). Be sure to do start it from a scheduler still in a way that it will only start it if it isn't running anymore (in case of an exception).

If you plan to run it from a scheduler and keep log files, you're recommended to use the run-sample.sh file as a start. It contains the basic cli invocation as a template. Fill in the argument values and adjust the script and log paths. Also, as a reminder that log files can run out of hand quickly, we've provided a sample file to use in logrotate (e.g. on Ubuntu). To learn about logrotate, checkout Ubuntu manpages or the Slicehost tutorial on the subject. To install it, copy the file to logrotate.conf within this directory, adjust the path and (if you want to) set different settings. Then move it to /etc/logrotate.d/testswarm-browserstack.conf.

Main scripts:


  1. testswarm-browserstack.js - Abstraction of TestSwarm API, and Scott González's BrowserStack API. Use it to automatically spawn BrowserStack workers based on your swarm's needs.
  2. cli.js - nodejs cli wrapper around it all. Allows for scripted or generally easy manual invocation of the script.

testswarm-browserstack.js


Options documentation:

  • browserstack.user: BrowserStack username
  • browserstack.pass: BrowserStack password
  • browserstack.project: Project name for grouping on BrowserStack Automate dashboard
  • browserstack.workerTimeout: Maximum lifetime of the worker (in seconds). Use 0 for indefinitely (BrowserStack will terminate the worker after the maximum run time, as of writing that maximum is 30 minutes).
  • browserstack.dryRun: Enable to only simulate spawning and termination of browserstack workers.
  • browserstack.totalLimit: Maximum number of simultaneous workers allowed under this BrowserStack account.
  • browserstack.eqLimit: How many simultaneous workers with the same browser are allowed.
  • testswarm.root: URL to the root of the TestSwarm installation. Relative to here should be ./index.php and ./api.php.
  • testswarm.runUrl: URL to the TestSwarm run page (including client name), for BrowserStack workers to open. If your swarm is protected with a token, this is the place to enter the token.
  • verbose: Output debug information (through console.log).

Example config.json:

{
  "browserstack": {
    "user": "example",
    "pass": "*******"
  },
  "testswarm": {
    "root": "http://ci.example.org/testswarm",
    "runUrl": "http://c.example.org/testswarm/run/JohnDoe"
  }
}

cli.js


This is a nodejs cli wrapper around testswarm-browserstack.js. You can use it independent of testswarm. Use --help to get all the information you need to know (see above for example usage):

  Usage: cli.js [options]

  Options:

    -h, --help            output usage information
    -V, --version         output the version number
    --config [path]       path to config file with options (defaults to ./config.json)
    --run                 Retrieve TestSwarm state and spawn/terminate BrowserStack workers as needed
    --run-loop <timeout>  Execute --run in a non-overlapping loop with set timeout (in seconds) between iterations
    --worker <id>         Get info abuot a specific BrowserStack worker
    --spawn <uaId>        Spwawn a BrowserStack worker by swarm useragent id (joining the swarm)
    --terminate <id>      Terminate a specific BrowserStack worker
    --terminateAll        Terminate all BrowserStack workers
    -v, --verbose         Output debug information (through console.log)
    --dry, --dry-run      Simulate spawning and termination of browserstack workers

testswarm-browserstack's People

Contributors

buley avatar clarkbox avatar jcook793 avatar jzaefferer avatar krinkle avatar mgol avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.