How to Implement Frontend Unit Testing using PHPUnit and Selenium RC - on this tutorial we'll learn how to implement UnitTesting, UnitTesting which is known to be applicable only on server side scripts. On this article we'll tackle ways of using PHPUnit and Selenium RC so as to test the output of our sites on any browsers.
I. Pre-Requisites
Before we proceed, we assume that you have the following components on your PC:
1. Java installed. For the server to run you’ll need Java installed and the PATH environment variable correctly configured to run it from the console. You can check that you have Java correctly installed by running the following on a console:
Online check: http://www.java.com/en/download/installed.jsp
If you get a version number (which needs to be 1.5 or later), you’re ready to start using Selenium-RC.
2. PEAR installed. The base installation that comes with the PHP distribution contains all the stuff that is needed to run the PEAR installation tools etc. If you have a recent installation of PHP, you can relax: The PEAR base installation is already there - unless you have compiled your PHP with the ./configure flag --without-pear.
Read more:
http://pear.php.net/manual/en/installation.introduction.php
3. XAMPP. XAMMP is an easy to install Apache distribution containing MySQL, PHP and Perl.
http://www.apachefriends.org/en/xampp.html
II. Install PHPUnit using PEAR installer
Run the following command:
Read more: http://pear.phpunit.de/
III. Install Selenium Remote Control
1. Download the latest Selenium RC from this location:
2. Extract selenium-server-standalone-x.x.x.jar and place it in any desired directory.
For this tutorial we put it in C:\xampp\php
IV. Start Selenium RC Server
Run this command on a separate console:
V. Selenium Sample PHP Test Script
1. Copy-paste the PHP code below and save it as test.php in any desired directory. For this tutorial we put it in C:\xampp\php
2. Create folder: C:\xampp\htdocs\screenshots
Run this command on a separate console:
This script creates list of AutoMD How-Tos to crawl based on existing links on http://www.automd.com/car-repair-guides-list/
If How-To page is missing breadcrumb, the script will take a screenshot, save it in C:\xampp\htdocs\screenshots, and continues to the next page.
References:
Chapter 18. PHPUnit and Selenium, http://www.phpunit.de/manual/current/en/selenium.html
PHPUnit PEAR Channel, http://pear.phpunit.de/
PEAR Introduction, http://pear.php.net/manual/en/installation.introduction.php
Selenium RC Documentation, http://seleniumhq.org/docs/05_selenium_rc.html
Selenium Reference, http://release.seleniumhq.org/selenium-core/0.8.0/reference.html
I. Pre-Requisites
Before we proceed, we assume that you have the following components on your PC:
1. Java installed. For the server to run you’ll need Java installed and the PATH environment variable correctly configured to run it from the console. You can check that you have Java correctly installed by running the following on a console:
C:\>java –version
Online check: http://www.java.com/en/download/installed.jsp
If you get a version number (which needs to be 1.5 or later), you’re ready to start using Selenium-RC.
2. PEAR installed. The base installation that comes with the PHP distribution contains all the stuff that is needed to run the PEAR installation tools etc. If you have a recent installation of PHP, you can relax: The PEAR base installation is already there - unless you have compiled your PHP with the ./configure flag --without-pear.
Read more:
http://pear.php.net/manual/en/installation.introduction.php
3. XAMPP. XAMMP is an easy to install Apache distribution containing MySQL, PHP and Perl.
http://www.apachefriends.org/en/xampp.html
II. Install PHPUnit using PEAR installer
Run the following command:
C:\xampp\php>pear channel-discover pear.phpunit.de
C:\xampp\php>pear install channel://pear.phpunit.de/PHPUnit
C:\xampp\php>pear install channel://pear.phpunit.de/PHPUnit
Read more: http://pear.phpunit.de/
III. Install Selenium Remote Control
1. Download the latest Selenium RC from this location:
http://seleniumhq.org/download/
2. Extract selenium-server-standalone-x.x.x.jar and place it in any desired directory.
For this tutorial we put it in C:\xampp\php
IV. Start Selenium RC Server
Run this command on a separate console:
C:\xampp\php>java -jar selenium-server-standalone-x.x.x.jar
V. Selenium Sample PHP Test Script
1. Copy-paste the PHP code below and save it as test.php in any desired directory. For this tutorial we put it in C:\xampp\php
2. Create folder: C:\xampp\htdocs\screenshots
Run this command on a separate console:
C:\xampp\php>phpunit test
This script creates list of AutoMD How-Tos to crawl based on existing links on http://www.automd.com/car-repair-guides-list/
If How-To page is missing breadcrumb, the script will take a screenshot, save it in C:\xampp\htdocs\screenshots, and continues to the next page.
<?php require_once 'PHPUnit/Extensions/SeleniumTestCase.php'; class test extends PHPUnit_Extensions_SeleniumTestCase { protected $autoStop = FALSE; protected $captureScreenshotOnFailure = TRUE; protected $screenshotPath = 'C:/xampp/htdocs/screenshots'; protected $screenshotUrl = 'http://localhost/screenshots'; function setUp() { $this->setTimeout(300); $this->setBrowser("*firefox"); $this->setBrowserUrl("http://www.automd.com/"); } function testMyTestCase() { $this->open("/car-repair-guides-list/"); for($i=1;$i<6;$i++) { $howto = "xpath=/html/body/div[@id='all']/div[@id='area']/div[@id='area-c']/div[@id='content']/div[@id='howto-".$i."']"; if($this->isElementPresent($howto)) { for($a=1; $a<26; $a++) { $ul1 = $howto."/ul[1]/li[$a]"; if($this->isElementPresent($ul1)) { $c++; $xpath[] = $link = $this->getAttribute($ul1."/a@href"); echo $link ."\n"; } $ul2 = $howto."/ul[2]/li[$a]"; if($this->isElementPresent($ul2)) { $c++; $xpath[] = $link = $this->getAttribute($ul2."/a@href"); echo $link ."\n"; } } } } foreach($xpath as $k => $v) { $this->checkBreadcrumb($v); } } function checkBreadcrumb($link) { $this->open($link); $this->waitForCondition($this->isElementPresent("//div[@id='content']/div[2]/div/h2"), 300000); $title = ($txt=$this->getText("//div[@id='content']/div[2]/div/h2")) ? $txt : 'blank title'; echo $title . "\n"; try { $this->assertContains($title, $this->getText("//div[@id='content']/div[1]")); } catch (PHPUnit_Framework_AssertionFailedError $e) { array_push($this->verificationErrors, $e->toString()); $this->drivers[0]->captureEntirePageScreenshot($this->screenshotPath . DIRECTORY_SEPARATOR . str_replace('/', '_', $link) . $this->testId . '.png'); } } }
References:
Chapter 18. PHPUnit and Selenium, http://www.phpunit.de/manual/current/en/selenium.html
PHPUnit PEAR Channel, http://pear.phpunit.de/
PEAR Introduction, http://pear.php.net/manual/en/installation.introduction.php
Selenium RC Documentation, http://seleniumhq.org/docs/05_selenium_rc.html
Selenium Reference, http://release.seleniumhq.org/selenium-core/0.8.0/reference.html