Super high value Continuous Integration test with Drupal, Jenkins and Selenium

Sometimes unit testing is a lot of work, especially if you have a system that has had many months of development without it.

One very valuable test is to check there are no errors in the Drupal log after you've committed new code.

First I clear the Drupal error log when Jenkins runs an update from version control using Drush:

cd /var/lib/jenkins/jobs/mysite
drush --uri=http://test.mysite.com watchdog delete all

Then when I run the Selenium tests I load all the major pages of the site and do some other clicking around. Finally I visit the dblog report and check there are no errors (The source code of the table below can be put directly into your Selenium test script, just omit the <table> tags, but this assumes you're using html based test suites):

The Selenium Steps

open /admin/reports/dblog
click link=Filter log messages
addSelection id=edit-severity label=emergency
addSelection id=edit-severity label=alert
addSelection id=edit-severity label=critical
addSelection id=edit-severity label=error
addSelection id=edit-severity label=warning
addSelection id=edit-severity label=debug
clickAndWait id=edit-submit
assertTextPresent No log messages available.

The Selenium Code

<tr>
  <td>open</td>
  <td>/admin/reports/dblog</td>
  <td></td>
</tr>
<tr>
<td>click</td>
<td>link=Filter log messages</td>
<td></td>
</tr>
<tr>
<td>addSelection</td>
<td>id=edit-severity</td>
<td>label=emergency</td>
</tr>
<tr>
<td>addSelection</td>
<td>id=edit-severity</td>
<td>label=alert</td>
</tr>
<tr>
<td>addSelection</td>
<td>id=edit-severity</td>
<td>label=critical</td>
</tr>
<tr>
<td>addSelection</td>
<td>id=edit-severity</td>
<td>label=error</td>
</tr>
<tr>
<td>addSelection</td>
<td>id=edit-severity</td>
<td>label=warning</td>
</tr>
<tr>
<td>addSelection</td>
<td>id=edit-severity</td>
<td>label=debug</td>
</tr>
<tr>
<td>clickAndWait</td>
<td>id=edit-submit</td>
<td></td>
</tr>
<tr>
  <td>assertTextPresent</td>
  <td>No log messages available.</td>
  <td></td>
</tr>

Post new comment

By submitting this form, you accept the Mollom privacy policy.

User login

Author of...

  • My blog about 'Time is NOT money'... and value http://t.co/g2C6pZy0 12 years 10 weeks ago
  • I've found an excellent query logging and filtering module for Drupal. Not available via http://t.co/U1Xe92Th: http://t.co/2qvg1DgE 12 years 14 weeks ago
  • I've just spotted my first © 2011 at the bottom of a website. 12 years 14 weeks ago
  • @da_lune That's the spirit, oh, too late @gavinbrook, Wordpress is fantastic & now more than a blogging tool but Drupal = more functionality 12 years 18 weeks ago
  • @oliverpolden is having an amazing day for many reasons. I feel like giving back: http://t.co/JvKVVMBF Have a request? use the contact form. 12 years 18 weeks ago
  • The world's population is 7 billion. If a few 'competing' companies mutually helped each other get more customers business would be easy. 12 years 18 weeks ago
  • @Casablanca Amazing photos! Thank you for sharing. 12 years 19 weeks ago
  • Ahh, the Christmas Snow module for Drupal: http://t.co/QzvkQiT2 12 years 19 weeks ago
Oliver Polden