Problem:
I want my application to work on all the environments I claim to support but I have no way of easily testing updates in each environment.
Bad Solution:
Continuously push to your remote to force Travis CI to test changes in multiple environments.
Good Solution:
Containerized unit testing with Dockunit.
Dockunit is a simple node command that lets you run your test framework of choice across a number of predefined containers. Each container can have it’s own test command and Docker image. It was born out of the need to ensure my PHP applications (WordPress specifically) were compatible with a spectrum of environments. Travis CI dropping support for PHP 5.2 was the final straw so I created this command for myself and decided to make it public.
Install/Usage Instructions for Dockunit
1. Ensure dependencies are met. See requirements on Github.
2. Install Dockunit
npm install -g dockunit
3. Setup project(s) with predefined containers.
To do this create a file called Dockunit.json
in the root of any project you want to run Dockunit on. Github contains specific guidelines for how to write Dockunit.json
files. Here is an example file for testing a WordPress plugin in PHP 5.2 FPM in WordPress 4.1, PHP 5.5 FPM in WordPress 4.0, and PHP 5.5 for Apache in WordPress 3.9:
{ "containers": [ { "prettyName": "PHP 5.2 FPM WordPress 4.1", "image": "tlovett1/php-5.2-phpunit-3.5", "beforeScripts": [ "service mysql start", "bash bin/install-wp-tests.sh wordpress_test root '' localhost 4.1" ], "testCommand": "phpunit" }, { "prettyName": "PHP 5.5 FPM WordPress 4.0", "image": "tlovett1/php-fpm-phpunit-wp", "beforeScripts": [ "service mysql start", "bash bin/install-wp-tests.sh wordpress_test2 root '' localhost 4.0" ], "testCommand": "phpunit" }, { "prettyName": "PHP 5.5 for Apache WordPress 3.9", "image": "tlovett1/php-apache-phpunit-wp", "beforeScripts": [ "service mysql start", "bash bin/install-wp-tests.sh wordpress_test3 root '' localhost 3.9" ], "testCommand": "phpunit" } ] }
3. Run Dockunit command.
dockunit
Note: This assumes you have changed directories to your project root. You may need to sudo
.
Detailed command usage instructions can be found on Github. Contributions and bug reports are encouraged :).