Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

grunt-protractor-runner

Package Overview
Dependencies
Maintainers
1
Versions
36
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

grunt-protractor-runner

A Grunt plugin for running protractor runner.

  • 0.2.5
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
11K
decreased by-5.74%
Maintainers
1
Weekly downloads
 
Created
Source

grunt-protractor-runner

A Grunt plugin for running Protractor runner.

Getting Started

This plugin requires Grunt ~0.4.1 and Protractor >=0.14.0-0 <1.0.0

If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:

npm install grunt-protractor-runner --save-dev

This plugin will install protractor module locally as a normal dependency. Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:

grunt.loadNpmTasks('grunt-protractor-runner');

If you want to use standalone selenium server, run ./node_modules/protractor/bin/webdriver-manager update to install/update the selenium server for local installed protractor.

The "protractor" task

Overview

In your project's Gruntfile, add a section named protractor to the data object passed into grunt.initConfig().

grunt.initConfig({
  protractor: {
    options: {
      configFile: "node_modules/protractor/referenceConf.js", // Default config file
      keepAlive: true, // If false, the grunt process stops when the test fails.
      noColor: false, // If true, protractor will not use colors in its output.
      args: {
        // Arguments passed to the command
      }
    },
    your_target: {
      options: {
        configFile: "e2e.conf.js", // Target-specific config file
        args: {} // Target-specific arguments
      }
    },
  },
})

Options

options.configFile

Type: String Default value: node_modules/protractor/referenceConf.js relative to where protractor module is installed.

A protractor config file.

options.keepAlive

Type: Boolean Default value: true

If true, grunt process continues even if the test fails. This option is useful when using with grunt watch. If false, grunt process stops when the test fails.

options.noColor

Type: Boolean Default value: false

If true, protractor will not give colored output. If false, protractor will give colored output, as it does by default.

options.debug

Type: Boolean Default value: false

If true, grunt will pass 'debug' as second argument to protractor CLI to enable node CLI debugging as described in Protractor Debugging documentation.

options.args

Type: Object Default value: {}

Arguments passed to the command. These arguments can also be supplied via command-line too. Ex.grunt protractor --specs=specs/some-test.js Supported arguments are below.

  • seleniumAddress string: A running selenium address to use
  • seleniumServerJar string: Location of the standalone selenium server .jar file
  • seleniumPort string: Optional port for the standalone selenium server
  • baseUrl string: URL to prepend to all relative paths
  • rootElement string: Element housing ng-app, if not html or body
  • specs array: Array of spec files to test. Ex. ["spec1.js","spec2.js"]
  • exclude array: Array of files to exclude from testing. Ex. ["spec2.js"]
  • suite string: Name of test suite to run
  • includeStackTrace boolean: Print stack trace on error
  • verbose boolean: Print full spec names
  • browser string: Browser name, e.g. chrome or firefox
  • params object: Param object to be passed to the test as browser.params
  • chromeDriver string: Location of chrome driver overridng the property in config file
  • chromeOnly boolean: Bypass Selenium for Chrome only testing
  • sauceUser string: Username for a SauceLabs account
  • sauceKey string: Access Key for a SauceLabs account
  • capabilities object: Capabilities object to be passed to the test, e.g. browserName, platform and version
  • framework string: Limited support for using mocha as the test framework instead of jasmine.
  • cucumberOpts object: Cucumber framework options object to be passed to the test, e.g. require, tags and format
  • mochaOpts object: Mocha test framework options object to be passed

Tests

Run npm install to install dependencies.

Then run grunt or npm test to test the module. You will encounter these.

  • It opens chrome a couple of times without warnings or errors.
  • A test task fails but the test process keeps alive and continues to the next test tasks.
  • It will launch the node debugger. You'll need to enter c a few times to progress through a few breakpoints, and then when it succeed, press Ctrl-c 2 times to exit the debugger to continue other test tasks.

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.

FAQ

Q: Want to global installed protractor?

This plugin installs protractor module locally as a normal dependency.

In case you want to use the plugin with the global installed protractor command. You can do it with these steps below.

  • Remove local install protractor by rm -rf node_modules/protractor
  • Install protractor globally with npm install -g protractor
  • Make sure that node can resolve the module with require() mechanism. See Module loding from the global folders for more information.
  • Run webdriver-manager update to install/update selenium driver for global install protractor.

Release History

  • 0.2.5
    • Support --mochaOpts, --suite and --exclude in options.args (#52, #53, #57)
  • 0.2.4
    • Support --cucumberOpts in options.args (#46)
  • 0.2.3
    • Temporarily remove automatically download/update webdriver-manager because it fails in some environment such as Windows (#41)
  • 0.2.2
    • Add protractor module as a normal dependency and automatically download/update webdriver with webdriver-manager after installed (#29, #39)
    • Support --framework in options.args (#36)
  • 0.2.1
    • Support --capabilities in options.args (#33)
  • 0.2.0
    • Able to use either local or global install protractor the same way as how require() function works (#29)
    • Move protractor from peerDependencies to devDependencies. These changes might break some user modules. (See FAQ above for explanation) (#29)
  • 0.1.11 - Support SauceLabs account config in options.args (#27)
  • 0.1.10
    • Support --chromeOnly in options.args (#23)
    • Support options.noColor to turn color off in protractor output (#24)
  • 0.1.9
    • Able to supply options.args via command-line arguments (#20)
    • Fixed merging task-level and target-level options
  • 0.1.8 - Support --chromeDriver in options.args (#17)
  • 0.1.7 - Support --browser and --params arguments passed to the protractor command using config in options.args (#12)
  • 0.1.6 - Change protractor(peerDependencies) to support version to 0.x (#8, #9, #10)
  • 0.1.5 - Added options.debug (#7)
  • 0.1.4 - Change protractor(peerDependencies) to support version to 0.10.x - 0.11.x (#6)
  • 0.1.3 - Fixed Windows command
  • 0.1.2 - Added keepAlive option.

Keywords

FAQs

Package last updated on 24 May 2014

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