/wp-plugin-template

WordPress plugin template

Primary LanguagePHP

WordPress Plugin Template for CI

This plugin can be used to start developing a new WordPress plugin. It has folder structure and build scipts included to support continious integration for plugin development.

Tool Setup

First install required tools:

sudo apt-get install git svn git-svn ant mysql-server-5.5

Setup git user preferences for system:

sudo git config --system user.name "John Doe"
sudo git config --system user.email john.doe@exmple.com

Install PHP and some of it's modules

sudo apt-get install php5-cli php-pear php5-xsl php5-xdebug

Set PEAR to autodiscover and install PEAR packages needed for CI

sudo pear config-set auto_discover 1
sudo pear install pear.phpqatools.org/phpqatools PHPDocumentor
sudo pear install pear.netpirates.net/phpDox-0.4.0

Also we will need WordPress coding standart sniffs

sudo git clone git://github.com/mrchrisadams/WordPress-Coding-Standards.git $(pear config-get php_dir)/PHP/CodeSniffer/Standards/WordPress

Jenkins Setup

Add Jenkins repo key to you system

wget -q -O - http://pkg.jenkins-ci.org/debian/jenkins-ci.org.key | sudo apt-key add -

Add following to your /etc/apt/sources.list file

#Jenkins APT repository
deb http://pkg.jenkins-ci.org/debian binary/

Update APT and install Jenkins

sudo apt-get update
sudo apt-get install jenkins

In some cases ant gives error that it can't load some file, this is what helped

sudo apt-get remove openjdk-6-*

cd to your home directory and download jenkins cli

cd ~
wget http://localhost:8080/jnlpJars/jenkins-cli.jar

Install Jenkins plugins and restart jenkins

java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin checkstyle
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin cloverphp
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin dry
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin htmlpublisher
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin jdepend
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin plot
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin pmd
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin violations
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin git
java -jar jenkins-cli.jar -s http://localhost:8080 install-plugin greenballs

java -jar jenkins-cli.jar -s http://localhost:8080 safe-restart

Now lets download a Jenkins template for WP Plugin development into jenkins jobs dir and reload Jenkins configuration

cd /var/lib/jenkins/jobs
sudo git clone https://github.com/martinssipenko/php-jenkins-template.git wp-plugin-template
sudo chown -R jenkins:nogroup wp-plugin-template/

cd ~
java -jar jenkins-cli.jar -s http://localhost:8080 reload-configuration

WordPress Unit Test Framework Setup

Create a /src directory for if you don't already have it

sudo mkdir /src

Clone WP Unit Test FW from it's offical SVN repo and make it accessible to all users

sudo svn co http://unit-test.svn.wordpress.org/trunk/ /src/wp_unit
sudo chmod -R 0777 /src/wp_unit

Create a MySQL databse for unit testing, never use existing db, you will loose all data

mysql -u root -p -e "DROP DATABASE wp_unit; CREATE DATABASE wp_unit;"

Configure WP Test Suite

cd /src/wp_unit
sudo cp wp-tests-config-sample.php wp-tests-config.php

Then edit wp-tests-config.php to connect to your database.

Create your plugin

Create a folder for your plugin and copy all files except README.md into your new plugin dir. Run git init to initialize repo for your plugin. Now create a new github repository and push you new plugin to it. You can use any versioning you wan't here but I preffer git & github.

git clone https://github.com/martinssipenko/wp-plugin-template.git /path/to/wordpress/wp-conetnt/plugins/wp-plugin-template

cd to your plugin dir and run phpunit

cd /path/to/wordpres/wp-conetnt/plugins/wp-plugin-template
phpunit --configuration build/phpunit.xml

Create a new Jenkins job from template

Open Jenkins in your browser http://localhost:8080 click in New Job, type a name for your job and select Copy existing Job and in Copy from type wp-plugin-template. Uncheck the Disable Build checkbox. In Source Code Management section choose your versioning system and fill required fields. In Build Triggers section choose Poll SCM. Click Save at the bottom of page. Now you can try to build you plugin, by clicking Build Now.

Further reading

Links