The Journey towards Continuous Integration
Upcoming SlideShare
Loading in...5

The Journey towards Continuous Integration



Over the past two years we’ve been pushing to improve our automated testing practices within Plusnet and to win full support for it within the company across the spectrum of fellow developers, ...

Over the past two years we’ve been pushing to improve our automated testing practices within Plusnet and to win full support for it within the company across the spectrum of fellow developers, project managers and upper management. It took a while to agree on software we want to use, and standards we want to follow, but now all new code is being continuously built and tested and the results of that are visible business-wide. We use PHP_CodeSniffer to verify that we follow our coding standards, PHPDocumentor to generate automated API documentation, PHPUnit to run test suites and phpUnderControl to run all these tools regulary, at least once a day and to generate aggregated reports. Finally, Sonar allows us to create and publish reports visible to everybody and more importantly reports that everybody can understand.
Setting it all up can be a tough exercise, but if you prepare to it upfront you might actually find it quite exciting! So, you strongly believe this is the way you should be developing your code, but you don’t really know where to start? Let me show you how our journey began. You don’t know how to convince your fellow developers to follow you? I’ll tell you how to establish a strong team that will follow you. Your managers seem to be more interested in delivering your project on time and don’t really see a point in spending additional time on unit testing and documenting your code? Maybe you haven’t shown them the benefits of continuous integration in a way they can understand.
I’ll show you what worked for us.



Total Views
Views on SlideShare
Embed Views



4 Embeds 111 101 7 2 1



Upload Details

Uploaded via as Adobe PDF

Usage Rights

CC Attribution License

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
Post Comment
Edit your comment

The Journey towards Continuous Integration The Journey towards Continuous Integration Presentation Transcript

  • PHP North West 2010 The Journey Towards Continuous Integration Sebastian Marek, Senior Software Engineer
  • @proofek  a Pole living in Sheffield  nearly 10 years PHP experience  co-author of 2 PHP books  big fan of process automation  TDD and CI  wants to be a knight
  • One Morning Long Ago
  • New experience  Alpha-box set up  New development processes  Staging platform and QA team  Deployment procedures  Fixing problems  Working on projects
  • At the Foot of Mount Doom  increased maintenance time  growing problem numbers  code harder to understand and follow  complex and time consuming testing
  • Looking for help!
  • First frustrations  ad hoc builds  mixture of php3 and php4  learn as you go  no standards
  • Forming up the fellowship  Stuart Grimshaw  Simon Westcott  Ben Selby  Sebastian Marek  Rowan Merewood  Ben Longden
  • Calling the council Who?  managers  developers What?  threats  opportunities  planning  implementation
  • It's always about the money  Design debt  Late fees  Interests
  • Finding the best way VS.
  • Support & roadmap
  • Metrics and reports
  • Joining more powerful allies
  • Automation
  • East front
  • Automated builds  Cruicecontrol addon  PHPUnit integration  phpDocumentor integration  code metrics generation  code coverage reports  checkstyle report integration  PHP Depend integration  PHPMD support  and many more
  • PHPUnit Industry recognised xUnit testing framework for PHP, supporting:  mock objects  database testing  code coverage analysis integrating  selenium RC  continuous integration platforms like CruiseControl, Hudson, Bamboo
  • phpDocumentor  automated documentation for PHP  supports different formats: HTML, PDF, CHM, XML  web and cli interface  easily configurable
  • PHP_Codesniffer  Based on defined coding standards  Detects coding standards violation  Extendable and configurable  Codebrowser
  • Code coverage report  Be always on top of your tests  Code coverage ratio  Configurable thresholds  Clover format  Html format
  • Software metrics - PHP Depend Code measures  Cyclomatic Complexity  NPath Complexity  CodeRank  Lines Of Code
  • PHP Mess Detector Intelligent code analyser  Possible bugs  Suboptimal code  Overcomplicated expressions  Unused parameters, methods, properties
  • Buildbox maintenance  New modules added  Increasing build time  Often crashes  Stability problems  Hardware issues
  • phpUnderControl
  • Upgrades needed
  • Hudson – next generation  easy installation  easy configuration  plugin support  distributed builds  multi-language support  dependency tracking
  • Hudson
  • More automation  git - distributed version control system  AIE – alpha integrated environment  capistrano  automated deployment  build script management
  • Selenium  Automated web apps testing  Regression testing  Headless builds
  • One ring to rule them all
  • West front
  • Sonar  quality management platform  continuous analysis  easily extendable and configurable
  • Sonar
  • Business wide visibility  Meaningful reports  Responsibility and ownership  KPI  Goals
  • Radiator view
  • Reports
  • The army needs to follow the leader  Lead by example  firm, but friendly and helpful  never forget about training  clear and simple rules  praise vs. punishment
  • You broke the build!
  • Where's the build?
  • Works on my machine?!
  • It's your time now
  • Quick guide 1. Investigate 2. Trial 3. Form a team 4. Small steps 5. Be visible 6. Automate
  • Resources  PHPUnit -  phpUnderControl -  Hudson -  Sonar -  phpDocumentor -  PHP_CodeSniffer -  PHP Depend -  PHP Mess Detector -  Selenium -  xDebug -
  • Q&A Any questions?