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...

  • @Casablanca Is javascript disabled in your browser? 13 years 39 weeks ago
  • Been listening to my loved #lastfm tracks for the past week via the chrome plugin goo.gl/kF48s and now my Recommended tracks are awesome! 13 years 39 weeks ago
  • @Casablanca I'm proud! 13 years 40 weeks ago
  • HTML5 Presentations make me happy, especially when they're about HTML5 goo.gl/Fx9Sp 13 years 41 weeks ago
  • @philhawksworth goo.gl/TLwWd 13 years 41 weeks ago
  • @philhawksworth for some reason I imagine you walking around with a monocle in one eye, pointing at code and stuff with a cane! 13 years 42 weeks ago
  • Ooh, the #ux prototyping in code bootcamp looks good http://www.uxbootcamp.org/ Go code! How about prototyping in #Drupal? 13 years 46 weeks ago
  • @markboulton You could do it with #Drupal n/o premium module goo.gl/JLUxN and the role sub module of Ubercart goo.gl/z4mxT goo.gl/dZ0SF 13 years 46 weeks ago
Oliver Polden