Hudson is written in Java so we will need to install Java, and to make things simpler we will install Hudson from its reporitory.
Edit /etc/apt/sources.list
and append every line that ends with “lenny main” with ” contrib non-free” and at the end of the file add this line
deb http://hudson-ci.org/debian binary/
This is needed because Java is not in Debians main repository. Your sources.list should look something like this
# deb http://ftp.hr.debian.org/debian/ lenny main deb http://ftp.hr.debian.org/debian/ lenny main contrib non-free deb-src http://ftp.hr.debian.org/debian/ lenny main contrib non-free deb http://security.debian.org/ lenny/updates main contrib non-free deb-src http://security.debian.org/ lenny/updates main contrib non-free deb http://volatile.debian.org/debian-volatile lenny/volatile main contrib non-free deb-src http://volatile.debian.org/debian-volatile lenny/volatile main contrib non-free deb http://hudson-ci.org/debian binary/
Update apt information
apt-get update
To install Java, Hudson and Ant (you do not need Ant if you plan to use Phing for building your project)
apt-get install sun-java6-jdk hudson ant
To start Hudson after installation enter
/etc/init.d/hudson start
Hudson should now be available through your browser at http://you-ip-address:8080
Once on Hudsons front page select Manage Hudson and then Manage Plugins and install this plugins:
Return to the Manage Hudson page and select Configure System. If you are using Ant, select Add Ant, uncheck “Install automatically” and under name enter “Ant 1.7.0” and for ANT_HOME enter /usr/share/ant
.
You can also enter settings for E-mail notifications.
Running automatic unit tests is probably the main reason for having a continuous integration server so lets install PHPUnit.
First make sure you have pear installed
apt-get install php-pear
To get the latest version of PHPUnit we will have to update our pear installer as well.
pear upgrade pear pear channel-update pear.php.net pear channel-discover pear.phpunit.de pear channel-discover components.ez.no pear channel-discover pear.symfony-project.com pear install phpunit/PHPUnit
PHPUnit requires Xdebug PHP extension, to install it
apt-get install php5-xdebug
Why we are at it, let's install some other useful tools for code metrics in you PHP projects.
PHP CodeSniffer:
pear install PHP_CodeSniffer
phploc (you must have pear channel pear.phpunit.de that we added while installing PHPUnit):
pear install phpunit/phploc
PHP Depend:
pear channel-discover pear.pdepend.org pear install pdepend/PHP_Depend-beta
To install phpDocumentor enter
pear upgrade PhpDocumentor
This is an example build.xml file that you should place in the root folder of your project and commit to your SCM before creating a new project in Hudson.
You will of course have to modify this file to match your environment.
<?xml version="1.0" encoding="UTF-8"?> <project name="NAME_OF_YOUR_PROJECT" default="build" basedir="."> <property name="basedir" value="${WORKSPACE}"/> <target name="init"> <!-- Create the different build directories --> <mkdir dir="${basedir}/build/logs" /> <mkdir dir="${basedir}/build/api" /> <mkdir dir="${basedir}/build/coverage" /> </target> <target name="clean"> <!-- Delete build directories from the previous run --> <delete> <fileset dir="${basedir}/build/logs" includes="**.*" /> </delete> <delete> <fileset dir="${basedir}/build/api" includes="**.*" /> </delete> <delete> <fileset dir="${basedir}/build/coverage" includes="**.*" /> </delete> </target> <!-- Default target --> <target name="build" depends="init,phpunit,php-documentor" /> <target name="php-documentor"> <exec executable="phpdoc" dir="${basedir}/gameplay"> <arg line="-ct type -t ${basedir}/build/api -ti 'Name of your project' -ue on -s -d ./ "/> </exec> </target> <target name="phpunit"> <exec executable="phpunit" dir="${basedir}/source/tests" failonerror="off"> <arg line="--log-xml ${basedir}/build/logs/phpunit.xml --log-pmd ${basedir}/build/logs/phpunit.pmd.xml --log-metrics ${basedir}/build/logs/metrics.xml --coverage-xml ${basedir}/build/logs/coverage.xml --coverage-html ${basedir}/build/coverage --coverage-clover ${basedir}/build/coverage/clover.xml --configuration phpunit.xml " /> </exec> </target> </project>
After the first successful build you can replace
<target name="build" depends="init,phpunit,php-documentor" />
with
<target name=“build” depends=“clean,init,phpunit,php-documentor” />
Return to the Hudsons front page and select “create a new jobs”.
If you are using Ant and the variation of the build file provided on this page click “Advanced” under Ant configuration and for Properties enter:
basedir=/var/lib/hudson/jobs/NAME_OF_YOUR_PROJECT/workspace
/var/lib/hudson/jobs/NAME_OF_YOUR_PROJECT/
is the place where Hudson will keep all informations about your project so it is important to pass this property to Ant so Ant can resolve path names that we are using in the Ants build file.
Other steps are optional and depend on you needs. I am using phpDocumentor to generate API docs for my project so I have selected Publish Javadoc and have entered “build/api/” as my Javadoc directory.
If you want to generate Clover Coverage Report using PHPUnit select Clover Coverage Report and enter build/coverage
for Clover report directory and clover.xml
for Clover report file name.
If you are using PHPUnit you probably want to check this options as well:
Check “Publish testing tools result report” select phpUnit from the dropdown menu and enter build/logs/*.xml
for PHPUnit Pattern.
Check “Publish PMD analysis results” and enter for PMD results enter build/logs/phpunit.pmd.xml
Save the setting and your first build should start.
PHPUnit requres a lot of memory, and default memory limit for PHP running on CLI is 32M. Edit /etc/php/cli/php.ini
and set memory_limit to 512MB if you have enough RAM installed.
Looking at the console output will help you to determine what went wrong during the build process.
That's about it.
You can visit my blog at http://gogs.info/.