Cloud Zone is brought to you in partnership with:

After teaching math (and a little computer science) for 14 years, Brian changed careers in 2006 with the idea that getting out of his comfort zone would be good. So now he works as a writer and programmer at Microsoft who specializes in PHP and Windows Azure. Brian is a DZone MVB and is not an employee of DZone and has posted 82 posts at DZone. You can read more from them at their website. View Full User Profile

Running VisualPHPUnit in Windows Azure

  • submit to reddit

Last month, I wrote a post that outlined 3 ways to test PHP applications in Windows Azure, and since then I’ve covered two of those approaches: Running PHPUnit in Windows Azure (uses RDP) and Automating PHPUnit Tests in Windows Azure. In this post I’ll cover how to use a web-front end (VisualPHPUnit specifically) to run tests in Azure.

If you have PHPUnit installed locally (and I’m assuming you have it installed as a PEAR package), then running VisualPHPUnit locally is a breeze – simply follow the directions in the README:       

1.Download and extract the project to a web-accessible directory.
2. Open config.php with your favorite editor.
    1.Change PEAR_PATH so that it points to the directory where PEAR is located.
    2.Update TEST_DIRECTORY so that it points to the root directory where your tests are stored.
3.Point your browser to the location where you installed VisualPHPUnit!

Note: I put VisualPHPUnit in my application root directory, which seemed to cause one problem: My tests are in the ‘tests” directory (which is in my application root). Each test has a require_once “.\ClassName.php” statement (as required by PHPUnit). However, when I browse to the VisualPHPUnit directory, the working directory is one directory “down”. So, I needed to change the require statements to require_once “..\ClassName.php” in order for the referenced files to be found. This is unfortunate if you have lots of tests, but I haven’t found a workaround yet (I’m certainly open to suggestions).

Once VisualPHPUnit is installed, continue developing/testing your application locally. When all your tests are passing and you are ready to move your application to Windows Azure, you’ll need to make two changes to the VisualPHPUnit configuration. Here’s what you need to do:

1. Edit VisualPHPUnit config.php file like so:

// The directory where PEAR is located
define('PEAR_PATH', dirname(getcwd()).'\bin\PHP\PEAR');

// The directory where the tests reside
define('TEST_DIRECTORY', dirname(getcwd()).'\tests');

Note: This assumes your tests directory is in your application root directory.

2. (Optional, but suggested): Password protect the VisualPHPUnit directory. Instructions for doing this are in this post: How to Password Protect a PHP Website Directory in Windows Azure.

3. Follow the steps for packaging and deploying a custom PHP installation in this post: Packaging a Custom PHP Installation for Windows Azure.

After you have deployed your app, you should be able to browse to the VisualPHPUnit directory, select and run your tests, and see the results:


That’s it!

Hope that’s helpful.




Published at DZone with permission of Brian Swan, author and DZone MVB.

(Note: Opinions expressed in this article and its replies are the opinions of their respective authors and not those of DZone, Inc.)