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

watirgrid

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

watirgrid

  • 1.1.5
  • Rubygems
  • Socket score

Version published
Maintainers
1
Created
Source

= WatirGrid

WatirGrid allows for distributed testing across a grid network using Watir.

== Getting Started To install WatirGrid: gem install watirgrid

=== The Basics

WatirGrid allows a local client to control remote Watir objects in parallel, hosted by providers on a grid network, via a central controller.

==== Key Terminology The controller implements a repository of tuples (tuple space) that can be accessed concurrently. The controller also hosts a ring server which advertises these tuples across a grid network making it loosely coupled.

Typically you will host one controller on a central machine. You will normally connect to this controller via a contoller_uri. You can also find this controller by its ring server, using a UDP broadcast for the ring server port.

The providers make remote Watir objects available to the tuple space hosted by the controller. Typically you will host one or many providers on your grid network, for example, each PC may become a single provider of a Watir tuple in the form of an Internet Explorer, Firefox, Safari or WebDriver browser object.

==== WatirGrid IS

  • A lightweight, pure Ruby implementation of distributed computing using DRb and Rinda.
  • A simple way to control remote Watir objects in parallel.
  • Cross platform friendly and works on Windows, OSX or Linux.
  • Open source, you're already looking in the right place if you want the source code.
  • WebDriver friendly, thanks to the wire protocol, WatirGrid happily runs with WebDriver implementations such as watir-webdriver and selenium-webdriver.

==== WatirGrid IS NOT

  • A "grid management" system. If you're looking to control individual resources, such as starting and stopping workstations or VMs you should look at the commercial implementation at Gridinit.com[http://gridinit.com]

  • Selenium Grid. If you're looking for a full blown implementation of distributed computing you should take a look at Selenium Grid[http://selenium-grid.seleniumhq.org/]

=== Simple Example

Pick a server to host the controller for the ring server and execute the following: $ controller

This should find your external facing IP and start the controller: I, [2011-04-09 18:06:19 #1971] INFO -- : Controller started on : druby://127.0.0.1:11235

On each remote machine, host the provider for the distributed (DRb) Watir object: $ provider -d watir -c druby://127.0.0.1:11235

This should find the recently started controller and register the provider: I, [2011-04-09 18:06:26 #1972] INFO -- : Provider started on : druby://127.0.0.1:11236 I, [2011-04-09 18:06:26 #1972] INFO -- : Controller found on : druby://127.0.0.1:11235 I, [2011-04-09 18:06:26 #1972] INFO -- : Provider registered : druby://127.0.0.1:11235

You will now be able to execute commands across remote browsers on your grid network.

e.g. require 'watirgrid'

Watir::Grid.control(:controller_uri => 'druby://127.0.0.1:11235') do |browser, id| puts "My remote browser id is #{id}" browser.goto("http://www.google.com") browser.text_field(:name, 'q').set("watirgrid") browser.button(:name, "btnI").click end

You may wish to host the controller and providers on different machines in a real scenario. You can specify things like server hostnames, ports and access control lists for each of the different types of servers. For more help see: $ controller --help Usage: controller [options]

Advanced Options: -h, --drb HOST Specify the DRb host for this controller to bind to. -p, --drb-port PORT Specify the DRb port for this controller to listen on. -H, --ring-server HOST Specify the ring server host for this controller to bind to. -P, --ring-server-port PORT Specify the ring server port for this controller to listen on. -a, --access-control-list ACL Specify a comma separated Access Control List -l, --log LEVEL Specify the logging level: - DEBUG - INFO - ERROR --help Show this message

$ provider --help Usage: provider -d DRIVER [options]

Basic Options: -d, --driver TYPE Specify driver type to use on this provider: - watir - webdriver - selenium - firewatir - safariwatir -c, --controller URI Specify the controller URI to register this provider on e.g.: - druby://127.0.0.1:11235 -b, --browser TYPE Specify the browser type to start when using webdriver or selenium: - firefox - chrome - ie

Advanced Options: -h, --drb HOST Specify the DRb host for this provider to bind to. -p, --drb-port PORT Specify the DRb port for this provider to listen on. -H, --ring-server HOST Optionally specify the ring server host if not using controller URI. -P, --ring-server-port PORT Optionally specify the ring server port if not using controller URI. -a, --access-control-list ACL Specify a comma separated Access Control List -l, --log LEVEL Specify the logging level: - DEBUG - INFO - ERROR --help Show this message

== Copyright

Copyright (c) 2009-2011 Tim Koopmans. See LICENSE for details.

FAQs

Package last updated on 12 Jun 2011

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