说实话,在代码质量方面,PHP 的压力很是大。经过阅读本系列文章,您将了解如何提升 PHP 代码的质量。php
咱们能够将此归咎于许多缘由,但这确定不只仅是由于 PHP 生态系统缺少适当的测试工具。在本文中,我想向您展现一个简单的设置,用于项目的基本质量测试。 我不会详述任何特定的工具,而是专一于设定测试环境。html
本文中有一个演示代码能够在 GitHub 上找到: https://github.com/mkosiedowski/php-testing-demo 若是你对这篇文章中的例子有任何问题,能够参考。git
我假设您熟悉 PHP 7.1 语法,您可使用 Composer 和 PSR-4 来进行自动加载和 PSR-1&PSR-2 的编码标准。在个人示例中,vendor 的二进制文件被安装到 ./bin 目录。github
咱们将使用一些不一样的测试工具,因此最好有一些能用一个脚原本运行它们的东西。 PHING 为咱们提供了解决此问题的绝佳解决方案。 PHing 与 Apache Ant 类似,可使用 XML 配置轻松自动执行任务。 咱们能够经过运行如下命令来安装它:composer
复制代码框架
$ php composer.phar require --dev phing/phing
而后,在项目的根目录中建立一些基本的 build.xml 文件。工具
<?xml version="1.0" encoding="UTF-8"?><project name="MyProject" default="run"></project>
在接下来的步骤中,咱们将添加一些由 PHing 运行的目标。post
我为了提升代码质量,您能够作的第一件事就是设置静态代码分析器。他们会在没有真正运行的状况下阅读你的错误代码。这就像在几秒钟内由一个机器人完成了一个代码审查同样。很酷,不是吗?单元测试
当使用正确的样式编写时,您的代码更容易维护。每一个人都知道(若是你不这样作,你至少应该开始阅读 Robert C. Martin 的“Clean Code”),但仍然有不少团队在遵照他们达成的标准方面存在问题。咱们能够用 phpcs - PHP 代码嗅探来自动化这个任务,有没有很神奇。测试
咱们能够经过运行如下命令来安装:
$ php composer.phar require --dev squizlabs/php_codesniffer
而后添加一个在 build.xml 中运行它的目标。你的 build.xml 如今应该是这样的:
<?xml version="1.0" encoding="UTF-8"?><project name="MyProject" default="run"> <target name="phpcs" description="Check code style with PHP_CodeSniffer"> <exec executable="bin/phpcs" passthru="true" checkreturn="true"> <arg line="--standard=PSR1,PSR2 -extensions=php src"/> </exec> </target> <target name="run" depends="phpcs"/></project>
如今您能够运行 ./bin/phing 了,phpc 将自动检查您是否在 PSR-1 和 PSR-2 编码标准上有任何错误。
许多框架,好比 Symfony,定义了它们本身的代码风格规则,咱们也能够自动检查这些规则。好比:若是您使用的是 Symfony 框架,请检查 https://github.com/leaphub/phpcs-symfony2 标准,以了解如何使用 phpcs 检查 Symfony 的标准。
错误格式的文件的示例输出:
MyProject > phpcs: FILE: /home/maciej/workspace/php-testing/src/Domain/Price.php-------------------------------------------------------------------------FOUND 1 ERROR AFFECTING 1 LINE-------------------------------------------------------------------------28 | ERROR | Method name "Price::get_value" is not in camel caps format-------------------------------------------------------------------------Time: 67ms; Memory: 6Mb
在代码评审期间,再也不浪费时间检查编码标准,从如今开始,它将自动实现!
重复的代码是很差的,每一个人都知道。有时咱们错误地建立了这样的代码,咱们历来没有注意到它。有时咱们这样作是由于咱们懒惰。最好是配备一个工具,它能够在构建时提示这个问题。PHPCPD - PHP 复制 / 粘贴检测器。
经过运行如下命令来安装它:
$ php composer.phar require --dev sebastian/phpcpd
而后将目标添加到 build.xml:
1 <target name="phpcpd" description="Generate pmd-cpd.xml using PHPCPD"> <exec executable="bin/phpcpd" passthru="true"> <arg line="src"/> </exec></target>...<target name="run" depends="phpcs,phpcpd"/>
在 vendor 目录上运行的重复代码检查的示例输出:
phpcpd 4.0.0 by Sebastian Bergmann. Found 74 clones with 2929 duplicated lines in 97 files: - /home/maciej/workspace/php-testing/vendor/phpspec/phpspec/src/PhpSpec/Matcher/TriggerMatcher.php:81-102 /home/maciej/workspace/php-testing/vendor/phpspec/phpspec/src/PhpSpec/Matcher/TriggerMatcher.php:114-135 - /home/maciej/workspace/php-testing/vendor/squizlabs/php_codesniffer/src/Reports/Full.php:81-114 /home/maciej/workspace/php-testing/vendor/squizlabs/php_codesniffer/src/Reports/Code.php:162-195 (...)
若是你从头开始你的项目,你应该看看 Phan - 它是一个很是强大的代码分析器,它会让你的代码变得漂亮。在 https://github.com/phan/phan 上查看。安装很是简单 - 只需安装 php-ast 扩展(在 Ubuntu 中,您能够尝试运行 sudo apt-get install php-ast)并运行:
$ php composer.phar require --dev phan/phan
而后建立一个配置文件 .phan/config.php 内容为:
<?phpreturn [ 'target_php_version' => '7.1', 'directory_list' => [ 'src', 'vendor/symfony/console', ], "exclude_analysis_directory_list" => [ 'vendor/' ],];
在 build.xml 文件中也建立 phan 目标:
<target name="phan" description="Check code with phan"> <exec executable="bin/phan" passthru="true" checkreturn="true"/></target>...<target name="run" depends="phpcs,phpcpd,phan"/>
如今,您能够运行您的代码分析,若是您犯了错误(例如……为类属性声明错误的 phpdoc 类型),您应该看到这样的消息:
MyProject > phan: src/Domain/PriceComparator.php:17 PhanTypeMismatchProperty Assigning \Domain\PriceConverter to property but \Domain\PriceComparator::priceConverter is intsrc/Domain/PriceComparator.php:35 PhanNonClassMethodCall Call to method convert on non-class type int
Phan 很神奇 - 它读取你的整个代码并对它执行屡次检查,包括将 phpdoc 声明与实际使用变量、方法、类等进行比较,你能够查看 https://github.com/phan/phan#features 的全部特征列表。
如今,您的项目中有三个彻底自动化的工具,能够保护您的代码的质量。您所须要作的就是手动运行 ./bin/phing,或者将其附加到您的 git-hook 或持续集成中。您的代码将被检查编码标准、重复和正式错误。这些检查应该会致使更可靠的运行时,而且花费在代码审查上的时间更少。
推荐阅读: