This is a follow up to yesterday’s post on headless browser testing using Selenium and PhantomJS. It was pointed out in the comments (thanks, shanna!) that by testing directly within PhantomJS and cutting out Selenium the tests would run even faster.
I’ve done a little proof of concept to rewrite my previous C# Selenium tests to run with CasperJS - a scripting and testing utility based on PhantomJS. The nice thing about CasperJS is that it can run tests and provide a simple output or it can export the results in the xUnit XML format (so it can be dropped into Jenkins).
The CasperJS API is well documented and there’s lots of examples of how to achieve common tasks. I will admit to struggling a little with getting an HTML <select>
to work properly, but everything else was relatively easy to adapt from the examples given.
var casper = require('casper').create();
casper.start('http://www.iproperty.com.my/', function() {
this.test.assertExists(
'select#s_searchBoxState',
'State dropdown is found'
);
this.test.assertExists(
'select#s_searchBoxState option[value="SE"]',
'Selangor option is found'
);
this.fill(
'form[name="frmSaleSearchbox"]',
{'searchBoxState': 'SE'},
false
);
this.click('#s_imgBtnSearch');
});
casper.then(function() {
this.test.assertTitle(
'All Residential For Sale In All Cities, Selangor for RM0 to RM999,999,999',
'Search results title is ok'
);
});
casper.thenOpen('http://www.iproperty.com.my/useracc/Login.aspx', function(){
this.test.assertExists('form#frm', 'Login form is found');
this.fill('form[id="frm"]', {
txtEmail: 'andy@andykelk.net',
txtPassword: 'xxxxx'
}, true);
});
casper.then(function() {
this.test.assertTitle('My Account', 'Login title is ok');
this.test.assertEquals(
this.evaluate(function() {
return __utils__.findOne('span.sidebar-text5').innerText}
),
'Andy',
'Account name is retrieved ok'
);
});
casper.run(function() {
this.test.done(6);
this.test.renderResults(true);
});
It’s about the same number of lines of code as the Selenium version of the same tests. Performance-wise, the two tests run with CasperJS in around 15 seconds compared to 25 to 30 seconds for the Selenium + PhantomJS version so there’s definitely a decent saving in execution time.
For us, JavaScript provides some advantages and disadvantages. On the positive side, almost all developers write some JavaScript and so are familiar with it and it’s a language common to all of our teams (be they PHP or .Net devs); on the downside, JavaScript is not core to anyone’s job and so it will be a mindset shift compared to writing tests in C#.
Cutting execution time for tests from 50+ seconds with Firefox to 15 seconds with CasperJS should provide many benefits to our team and our testing.