-
Notifications
You must be signed in to change notification settings - Fork 44
Home
h2. Background
Venus is a testing tool for JavaScript (JS), which simplifies running unit tests.
When you are developing a browser-based project in JS, you'll want to create unit tests and run them frequently. To run one of your tests in the browser, you typically need to generate a test fixture page.
Rather than create an entirely new testing library, we set out to create a tool to make it easier for you to work with an existing library.
h3. Pains of running unit tests
Generating and running the test fixture page is often a manual process (e.g, defining library, dependencies, code want to test, some initialization code).
There is often no easy way to integrate running tests from an IDE, since there is no command line output from running the test.
h3. Venus comes to the rescue
Use simple annotations in your tests to specify which testing library you want to use, the file you are testing, other file dependencies, and a test fixture page template.
Quickly run your browser-based tests directly from the command line using PhantomJS.
Run your tests from the command line in multiple browsers (running locally or remotely) at the same time.
Integration with Continuous Integration tools (Hudson + Selenium Grid).
h2. Setup
Install [Node.js|http://nodejs.org/]
{code:JavaScript} // Mac OS X // Use the Macintosh Installer on the Node.js website (e.g., node-v0.8.6.pkg)
// Linux RHEL // Download source code from Node.js website (e.g., node-v0.8.6.tar.gz) tar -zxf node-v0.8.6.tar.gz cd node-v0.8.6 ./configure make sudo make install {code}
Clone the Venus repository from GitHub {code:JavaScript} git clone [email protected]:sethmcl/venus.git {code}
Install Node.js packages {code:JavaScript} npm install {code}
h2. Running Unit Tests
To run a unit test locally using PhantomJS, use the following command from the Venus directory: {code:JavaScript} bin/venus exec -t path/to/test/foo.js -n {code}
Socket.IO is started to handle communication between the client and server. An executor is created to run the unit test on the browser.
If the option is passed to the command, a PhantomJS browser is launched locally to run the unit test.
If the option is not passed to the command, copy the URL from the console to any browser to run the unit test.
Usage:
|| Option || Description || | \-n, \--phantom | Use PhantomJS client to run browser tests | | \-t, \--test | Comma separated string of tests to run |
h2. Overview
We will give an overview of the code base
- bin/venus*
- Venus.js*
Defines commands and options that can be used with Venus via commander.js commander.js is also used to parse command line arguments When is passed a command line argument, is called
Checks if overlord URL is defined (similar to InsFrame master/slave configuration) Calls
- lib/executor.js*
Calls to set up application environment by creating HTTP server and defining directory paths for files/dependencies Creates test groups of all unit tests passed in as command line arguments Checks if overlord and PhantomJS are defined Calls to define routes via Express (executor assigns id to every test case that is loaded starting at 1 and auto increments) Calls to find open port for executor to run on Executor runs unit tests one by one
- .venus directory*
- adapters => bridge files between library/framework and Venus that will normalize output to console
- libraries => libraries/frameworks that Venus supports
- templates => dust templates for the test fixture pages
- test file (e.g., test/data/sample_tests/planet.js)*
- @venus-library => library/framework that you want to use
- @venus-template => test fixture template (uses default test fixture template if not defined)
- @venus-include => JS file to include with test (create @venus-include for each JS file)
We use the i18n and locale node packages to define the language for Venus console output:
{code:JavaScript} bin/venus exec -l en \\ English bin/venus exec -l pirate \\ Pirate Speak {code}
h2. Selenium Grid/Continuous Integration (Hudson)
Super grid is LinkedIn's interpretation of selenium grid that will allow Venus to run unit tests remotely.
Selenium grid allows your to write regular selenium scripts to define a unit test on a specified browser and URL. You are able to send requests to a controller server that is responsible to get a VM up and running with a URL you define. It basically acts like a black box to run unit tests.
The former approach was to host our own browsers on a server. Connections to the server where not consistent which led to it not being manageable and scalable.
An integration between Venus and super grid will help with pre and post commits.
h2. What's Next
- Build adapters for QUnit and Jasmine
- Work on selenium integration to run tests remotely
- Add different format for test results
- Have unit tests running in PCS/PCL
If you run into issues with Node.js version, make sure to update Node.js:
If you run into issues with phantonjs-node, run the following commands inside the Venus directory {code:JavaScript} git submodule init git submodule update {code}
The following warning occurs due to new versions of certain node packages (e.g, express): {code:JavaScript} Warning: express.createServer() is deprecated, express applications no longer inherit from http.Server, please use:
var express = require("express"); var app = express();
- simply replace all occurences of "express.createServer()" with "express()"
{code}
All you have to do is simply replace all occurences of with in the Venus project directory. However, a GitHub issue will be created to the resolve issue.