Combine the power of casperjs' automation with Mocha's robust testing framework features
- automatically load Casper, Mocha, and optionally chai and casper-chai
- automatically run your Casper steps after each test
- use any Mocha reporter that can run in the phantomjs environment
For example, let's rewrite Casper's google testing example
describe('Google searching', function() {
before(function() {
casper.start('http://www.google.fr/')
})
it('should retrieve 10 or more results', function() {
casper.then(function() {
'Google'.should.matchTitle
'form[action="/search"]'.should.be.inDOM.and.be.visible
this.fill('form[action="/search"]', {
q: 'casperjs'
}, true)
})
casper.waitForUrl(/q=casperjs/, function() {
(/casperjs/).should.matchTitle
})
})
})
npm install -g mocha-casperjs
mocha-casperjs
Like Mocha, if you place your tests in the test
or tests
directory, it will find them and run them. You can also specify tests to run individually instead.
Note that mocha-casperjs has peer dependencies on casper and mocha, and will be installed ajacent to where you are installing mocha-casperjs (e.g. if you install mocha-casperjs globally, you'll have mocha and casperjs also installed globally).
Note that slimerjs isn't supported at the moment
If chai is discovered (it must be installed adjacent to mocha-casperjs), it will automatically use the should
style as well as expose expect
globally.
If casper-chai is discovered, it will be used with chai.
The selectXPath casper helper method is exposed globally as xpath
.
In addition to specifying options on the command line, you can add them to a mocha-casperjs.opts
like mocha.opts, except it looks for this file in the current directory.
--reporter
--timeout
--grep
--ui
--invert
--no-color
--slow
--bail
These are all Mocha command line options that mocha-casperjs supports. Currently the default timeout is 30 seconds, not two, as writing end to end tests takes more time.
Note the CasperJS cli parser does not support shorthands or spaces between parameters. So rather than -g foo
and --grep foo
, use --grep=foo
--casper-timeout=<timeout in ms>
Set Casper's timeout. If not set, no timeout will happen. This is one overall timeout for the entire test run.
--wait-timeout=<timeout in ms>
Set Casper's waitTimeout, the timeout used by the waitFor*
family of functions. If not set, the casper default is used (as of this writting, it is 5 seconds)
--step-timeout=<timeout in ms>
Set Casper's stepTimeout, the timeout for individual steps. If not set, the casper default is used (as of this writing, no timeout is set).
--file=<file>
Pipe reporter output to the specified file instead of standard out. Use this if you have to filter out console messages from reporter output, like for json
, xunit
, etc. type of reporters
--mocha-path=<path>
Load Mocha from the specified path, otherwise look for it adjacent to mocha-casperjs
--chai-path=<path>
Load Chai from the specified path, otherwise look for it adjacent to mocha-casperjs
--casper-chai-path=<path>
Load casper-chai from the specified path, otherwise look for it adjacent to mocha-casperjs
Also, you can add CasperJS options to mocha-casperjs.opts
. Below are the supported options:
--user-agent
--viewport-width
--viewport-height
--client-scripts
--user-agent=<userAgent>
Sets the User-Agent
string (like Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)
) to send through headers when performing requests.
--viewport-width=<pixels> --viewport-height=<pixels>
Sets the PhantomJS
viewport to custom size. Useful for testing media queries and capturing screenshots:
casper.on('load.finished', function (resource) {
this.captureSelector(screenshots_path + 'body.png', 'body');
});
--client-scripts=<file1>,<file2>
A comma seperated list of files to inject into the remote client every page load.
You can provide your own reporter via the --reporter
flag. mocha-phantomjs will try to require
the module and load it. Some things to take note of:
- Both node modules and script files can be required, so for relative paths to scripts, make sure they start with '.'. E.g. use
--reporter=./foo
to loadfoo.js
that is in the current directory. CoffeeScript files can be directly required too, as phantomjs has coffeescript built in. - PhantomJS is not node.js. You won't have access to standard node modules like
url
,http
, etc. Refer to PhantomJS's built in modules. However, mocha-casperjs does provide a very minimalisticprocess
shim to PhantomJS'ssystem
module. - If you want access to built-in Mocha reporters, they are available on
Mocha.reporters
. For example,Mocha.reporters.Base
.
- Only call
casper.start
once. casper initializes state in this call and it doesn't support being called twice. usecasper.thenOpen
if you need to navigate to another page later on - Make sure your casper operations are in a step. If a step isn't added in a test or test hook, mocha-casperjs will not tell mocha to wait for casper.
- Capser's timeout is overall for the entire test run, and mocha's timeout is per hook/test. Casper uses separate timeouts for waits, and they can be overridden every
waitFor
call. Mocha also allows overridding timeout per test and hook.
mocha-casperjs is a big conglomeration of various ideas and approaches.
- It patches Mocha's
Runnable
to have every runabble be async and flush the casper tests - an approach taken from mocha-as-promised. - It replaces
Mocha.process.stdout
with phantom's, including formatting - an approach taken from mocha-phantomjs - It attaches to Casper error events and fails the test with the last error that occoured.