Integração Contínua com Cruise Control e phpUnderControl

Loading...

Flash Player 9 (or above) is needed to view presentations.
We have detected that you do not have it on your computer. To install it, go here.

0 comments

Post a comment

    Post a comment
    Embed Video
    Edit your comment Cancel

    2 Favorites

    Integração Contínua com Cruise Control e phpUnderControl - Presentation Transcript

    1. PHP Conference 2008
    2.  Diego Tremper  Zend Certified Engineer  Entusiasta PHP  Estudante
    3.  Integração Contínua  CruiseControl  phpUnderControl  PHPUnit  phpDocumentor  PHP_CodeSniffer  Métricas  Prática
    4. “Integração Contínua é uma prática de desenvolvimento de software em que membros de um time integram seu trabalho frequentemente, normalmente cada membro faz integrações diariamente, conduzindo a multiplas integrações diárias. Cada integração é verificada por um build automático (incluindo testes) para detectar erros o mais rápido possível.” Martin Fowler
    5. Cotidiano de um time de desenvolvimento: Dev A Dev C Repositório (CVS, SVN, etc) Dev B Dev D
    6.  Como detectar problemas de integração de maneira mais rápida?  Como descobrir se a alteração na tela X não causou problemas na telaY?  Quanto maior o projeto…  Maior a complexidade…  Maior o reaproveitamento…  Maior a probabilidade de ocorrerem problemas de integração!
    7. Script Servidor de Repositório Integração Contínua (CVS, SVN, etc) Feedback Dev B Dev C Dev D
    8.  Desenvolvedor publica suas modificações em qualquer sistema de controle de versão (SVN, CVS, etc)  A partir de uma definição, o CruiseControl periodicamente procura por modificações no código (config.xml)  Dispara um novo build (build.xml)  Captura e armazena os logs e artefatos gerados a partir do build  Publica o resultado do build e os artefatos gerados (web, email, etc)
    9.  Acelera a detecção de bugs  Reduz os riscos  Reduz o tempo de integração  Aumenta a confiança do time  Agiliza o feedback  Facilita o refactoring
    10. O CruiseControl é um framework para a automatização do processo de build  Inclue plugins de integração com diversas ferramentas de controle de código  Prove interface web para visualização de relatórios sobre os builds realizados  É gratuíto e de código aberto (BSD license)
    11.  Arquitetura
    12. O phpUnderControl é uma customização do CruiseControl que permite a fácil integração de ferramentas de controle de códigos PHP  phpDocumentor  PHPUnit  xDebug  PMD  PHP_CodeSniffer
    13.  Modifica mecanismos de publicação do CruiseControl para que sejam mais focados a projetos PHP  A partir dos logs gerados no build, gera os gráficos para visualização das métricas  Provê interface (linha de comando) para manutenção de projetos monitorados
    14.  Provê feedback  Documentação do código  Execução de testes  Cobertura dos testes (code coverage)  Métricas ▪ Complexidade ▪ Risco ▪ ...  Violação de padrões
    15. Instalação CruiseControl $ unzip cruisecontrol-bin-2.7.3.zip -d /opt $ ln -s /opt/cruisecontrol-bin-2.7.3 /opt/cruisecontrol $ /opt/cruisecontrol/cruisecontrol.sh Algumas configurações de startup podem ser configuradas neste arquivo (JAVA_HOME, porta, etc)
    16. Instalação phpUnderControl $ pear config-set preferred_stable beta $ pear channel-discover components.ez.co $ pear channel-discover pear.phpunit.de $ pear install –alldeps phpunit/phpUnderControl Aplica o patch na instalação do Cruise Control. Não esquecer de adicionar os executáveis do PHP_CodeSniffer, PHPUnit, phpDocumentor no PATH!!! Todos disponíveis no diretório de binários do PHP (phpcs, phpunit, phpdoc)
    17. Instalação phpUnderControl $ /usr/local/php5/bin/phpuc install /opt/cruisecontrol
    18. Lista de projetos monitorados
    19. Execução de testes
    20. Documentação do Código
    21. Violação de padrões
    22. Violação de padrões  Possibilita ao desenvolvedor visualizar possíveis violações no padrão de código adotado para a escrita do projeto (PHP e JavaScript).  Suporta alguns padrões de escrita conhecidos (PEAR, Zend, etc), mas existe a possibilidade de extensão  Integra com Zend Code Analyzer
    23. Cobertura dos testes
    24. Métricas
    25. Complexidade Ciclomática  Mede o número de caminhos independentes de um método  Considera contruções if, for, &&, case, while, etc.  Interpretação  Maior complexidade leva a mais erros  Maior complexidade faz o teste mais difícil
    26. CRAP (Change Risk Analysis and Predictions )  Estima o esforço/tempo para a alteração de uma unidade de código  Considera a cobertura dos testes e a complexidade ▪ Menor cobertura => Maior risco ▪ Maior cobertura => Risco similar à complexidade
    27. Criando um projeto de exemplo $ /usr/local/php5/bin/phpuc example --project-name phpconference2008 /opt/cruisecontrol Opção para criação de um projeto de Nome do novo projeto exemplo e uma sub-opção para o nome do projeto Diretório de instação do CruiseControl
    28. Estrutura de diretórios /opt/cruisecontrol |-- artifacts | | |-- phpconference2008 | |-- 20081008002858 Os artefatos gerados em cada build | | | | | | |-- api |-- coverage ficam arquivados para visualização | | | | `-- graph `-- project-abc futura | `-- project-xyz |-- config.xml |-- cruisecontrol.sh |-- logs | |-- conaphp Arquivo monitorado pelo loop | | `-- project-abc `-- project-xyz principal do CruiseControl |-- projects |-- conaphp | |-- build | | |-- api | | | | |-- coverage `-- logs Arquivo de configuração do build do | | |-- build.xml `-- source projeto define as tarefas a serem | | |-- src | `-- Math.php executadas | `-- tests | `-- MathTest.php `-- project-abc `-- project-xyz
    29.  Configuração do CruiseControl (config.xml) <cruisecontrol> … Nome projeto <project name=“phpconference2008\" buildafterfailed=\"false\"> <schedule interval=\"300\"> Agendamento <ant anthome=\"apache-ant-1.7.0“ buildfile=\"projects/${project.name}/build.xml\"/> </schedule> … <publishers> <currentbuildstatuspublisher file=\"logs/${project.name}/buildstatus.txt\"/> <artifactspublisher dir=\"projects/${project.name}/build/api” dest=\"artifacts/${project.name}\" subdirectory=\"api\"/> <artifactspublisher dir=\"projects/${project.name}/build/coverage“ dest=\"artifacts/${project.name}\" subdirectory=\"coverage\"/> <execute command=\"/usr/local/php5/bin/phpuc \\ graph logs/${project.name} artifacts/${project.name}\"/> </publishers> </project> … </cruisecontrol> Gera os gráficos
    30.  Configuração do Ant (build.xml)  Organização ▪ Project: é a tag raiz do build.xml, ele representa todo o projeto e só pode existir um por buildfile. ▪ Target: é uma coleção de tarefas que desejamos aplicar em determinado momento e encadeando junto com outras tarefas. ▪ Task: é uma tarefa que desejamos que seja feita dentro do target, o Ant já disponibiliza tarefas prontas, porém é possível criar novas. ▪ Property: é um parâmetro em forma de nome-valor necessário para configurar nossa aplicação.
    31.  Configuração do Ant (build.xml) <project name=“phpconference2008\" default=\"build\" basedir=\".\"> <property name=“src” value=“${basedir}/src” /> <property /> <property /> <target name=“build” depends=“checkout”> <task /> <task /> </target> <target name=“checkout” > <echo>Baixando código do repositório…</echo> <task /> </target> </project>
    32.  Configuração do Ant (build.xml) <project name=“phpconference2008\" default=\"build\" basedir=\".\"> <target name=\"build\" depends=\"php-documentor,php-codesniffer,phpunit\"/> <target name=\"php-documentor\"> <exec executable=\"phpdoc\" dir=\"${basedir}/source\" logerror=\"on\"> <arg line=\"--title '${ant.project.name}' -ue on -t ${basedir}/build/api \\ -d src -tb '/usr/local/php5/lib/php/data/phpUnderControl/data/phpdoc' \\ -o HTML:Phpuc:phpuc\"/> </exec> </target> <target name=\"php-codesniffer\"> <exec executable=\"phpcs\" dir=\"${basedir}/source“ output=\"${basedir}/build/logs/checkstyle.xml“ error=\"/tmp/checkstyle.error.log\"> <arg line=\"--report=checkstyle --standard=PEAR src\"/> </exec> </target> …
    33.  Configuração do Ant (build.xml) .. <target name=\"phpunit\"> <exec executable=\"phpunit\" dir=\"${basedir}/source\" failonerror=\"on\"> <arg line=\" --log-xml ${basedir}/build/logs/phpunit.xml \\ --log-pmd ${basedir}/build/logs/phpunit.pmd.xml \\ --log-metrics ${basedir}/build/logs/phpunit.metrics.xml \\ --coverage-xml ${basedir}/build/logs/phpunit.coverage.xml \\ --coverage-html ${basedir}/build/coverage \\ PhpUnderControl_Example_MathTest tests/MathTest.php\"/> </exec> </target> </project>
    34. Perguntas?
    35. Obrigado!!! Contato: diegotremper@gmail.com LinkedIn: http://www.linkedin.com/in/diegotremper Blog: http://www.diegotremper.com
    36.  http://www.diegotremper.com  http://cruisecontrol.sourceforge.net/  http://ant.apache.org/  http://www.phpundercontrol.org/  http://www.phpunit.de/  http://pear.php.net/package/PHP_CodeSniffer  http://www.phpdoc.org/

    + diegotremperdiegotremper, 11 months ago

    custom

    1233 views, 2 favs, 3 embeds more stats

    Palestra feita no PHPConference 2008

    More info about this document

    © All Rights Reserved

    Go to text version

    • Total Views 1233
      • 919 on SlideShare
      • 314 from embeds
    • Comments 0
    • Favorites 2
    • Downloads 29
    Most viewed embeds
    • 296 views on http://blog.diegotremper.com
    • 17 views on http://planet.prophp.com.br
    • 1 views on http://64.233.163.132

    more

    All embeds
    • 296 views on http://blog.diegotremper.com
    • 17 views on http://planet.prophp.com.br
    • 1 views on http://64.233.163.132

    less

    Flagged as inappropriate Flag as inappropriate
    Flag as inappropriate

    Select your reason for flagging this presentation as inappropriate. If needed, use the feedback form to let us know more details.

    Cancel
    File a copyright complaint
    Having problems? Go to our helpdesk?

    Categories