当前位置: 首页 > 图文教程 > 网络编程 > PHP > PHPUnit袖珍指南之命令行测试工具

PHP
让我们来编写一些PHP实用的脚本
七种缓存使用武器 为网站应用和访问加速
动态网页PHP中引用&的使用注意事项
在PHP中全面阻止SQL注入式攻击
PHP自带可以代替echo调试的unit函数
小结:PHP动态网页程序优化及高效提速问题
php对特殊语句查询结果进行数组排序
实例:用PHP技术解决网站URL格式过长的问题
小结:PHP动态网页程序两个有用的小技巧
动态网页中直接不让访问PHP程序文件
网页实例:详细介绍用PHP来编写网页记数器
菜鸟学习:动态网页PHP基础学习笔记
利用Apache实现禁止图片盗链
PHP编程中常用的三则技巧
PHP制作的网站意见在线反馈表
大型Web需求解决方案 PHP定位突出
PHP实例:精确到每一秒钟的在线人数显示代码
实用:动态网页制作技术PHP的十个应用技巧
常见php页面漏洞分析及相关问题解决
PHP和MYSQL制作动态网站开发经验之谈

PHPUnit袖珍指南之命令行测试工具


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 58 ::
收藏到网摘: n/a

PHPUnit命令行测试工具是通过phpunit命令调用的。如下代码显示如何通过PHPUnit命令行测试工具运行测试。

  phpunitArrayTest
PHPUnit2.3.0bySebastianBergmann.

Time:0.067288

OK(2tests)
对每个测试,PHPUnit命令行测试工具打印一个字符表示进程:

·测试成功打印“.”。

·运行测试方法是发生了断言失败打印“F”。

·运行测试方法是发生了错误打印“E”。

·测试没有完成或测试没有实现打印“I”(见本书后“未完成的测试”一章)。

PHPUnit可以区分失败和错误。一个失败是PHPUnit的断言违例,错误是一个意料外的异常或一个PHP错误。有时候这种差别是有用的,因为错误相比失败更容易修正。如果你有一大串问题列表,最好先解决所有错误,然后看看有没有失败遗留下来。

让我们看看如下一些代码命令行测试工具的选项:

    phpunit--help
PHPUnit2.3.0bySebastianBergmann.

Usage:phpunit[switches]UnitTest[UnitTest.php]
--coverage-data<file>Writecode-coveragedatainrawformattofile.
--coverage-html<file>Writecode-coveragedatainHTMLformattofile.
--coverage-text<file>Writecode-coveragedataintextformattofile.
--testdox-html<file>WriteagiledocumentationinHTMLformattofile.
--testdox-text<file>WriteagiledocumentationinTextformattofile.
--log-xml<file>LogtestprogressinXMLformattofile.
--loader<loader>TestSuiteLoaderimplementationtouse.
--skeletonGenerateskeletonUnitTestclassforUnitinUnit.php.
--waitWaitsforakeystrokeaftereachtest.
--helpPrintsthisusageinformation.
--versionPrintstheversionandexits.
phpunitUnitTest

运行类UnitTest提供的测试,该类应该定义在源文件UnitTest.php中。

类UnitTest必须继承PHPUnit2_Framework_TestCase类,或是提供了公有静态方法suite,并返回PHPUnit2_Framework_Test对象的类(例如,类PHPUnit2_Framework_TestSuite的一个实例)

phpunitUnitTestUnitTest.php

运行类UnitTest提供的测试,该类要定义在命令指定的源文件(UnitTest.php)中。

--coverage-data,--coverage-html,and--coverage-text

控制运行测试的代码覆盖信息的分析和集合(参见本书后代码覆盖分析一节)

--testdox-htmland--testdox-text

以HTML或普通文本格式生成运行测试的敏捷文档(参见本书后的“测试的其他用途”一章)

--log-xml

生成运行测试的XML格式的日志文件。

下一个例子显示为ArrayTest中的测试生成的XML日志文件。

    <?xmlversion="1.0"encoding="UTF-8"?>
<testsuites>
 <testsuitename="ArrayTest"tests="2"failures="0"errors="0"time="0.020026">
 <testcasename="testNewArrayIsEmpty"class="ArrayTest"time="0.014449"/>
 <testcasename="testArrayContainsAnElement"class="ArrayTest"time="0.005577"/>
</testsuite>
</testsuites>
下面的XML日志文件是为名为FailureErrorTest的测试类两个测试生成的,一个是testFailure,一个是testError。这显示了失败和错误是如何分别表示的。

    <?xmlversion="1.0"encoding="UTF-8"?>
<testsuites>
 <testsuitename="FailureErrorTest"tests="2"failures="1"errors="1"time="0.013603">
 <testcasename="testFailure"class="FailureErrorTest"time="0.011872">
 <failuremessage=""type="PHPUnit2_Framework_AssertionFailedError"></failure>
</testcase>
<testcasename="testError"class="FailureErrorTest"time="0.001731">
 <errormessage=""type="Exception"></error>
</testcase>
</testsuite>
</testsuites>
--loader
指定将要使用的测试套件加载器。

标准测试套件加载器会在当前工作目录和PHP的include_pathconfiguration指令定义的路径中寻找源文件。按照PEAR的命名规则,形如Project_Package_Class的类名会映射到的源文件为Project/Package/Class.php。

--skeleton

为类Unit(在文件Unit.php中)生成一个名为UnitTest(在文件UnitTest.php中)的测试用例类的框架。对原始类的每个方法,在生成的测试用例类中提供了一个未完成的测试用例(见本书后的“未完成测试”部分)。

下面的例子显示了如何为一个名为Sample的类生成一个测试类的框架。

    phpunit--skeletonSample
PHPUnit2.3.0bySebastianBergmann.
WrotetestclassskeletonforSampleto
SampleTest.php.
phpunitSampleTest
PHPUnit2.3.0bySebastianBergmann.
I
Time:0.007268
Therewas1incompletetestcase:
1)testSampleMethod(SampleTest)
OK,butincompletetestcases!!!
Testsrun:1,incompletetestcases:1.
当你为现有代码书写测试时,你不得不重复很多相同的代码片断,如:

    publicfunctiontestSampleMethod(){}
PHPUnit能帮助你分析现有代码,生成测试用例类的框架。

--wait

每个测试结束时,等待一次击键。这很有用,特别是你在一个只有测试一直运行在打开的窗口中运行测试时。

提示当被测试代码中有PHP语法错误时,文本界面的测试会直接退出,不输出任何错误信息。标准的测试套件加载器会检查测试套件的源文件的PHP语法错误,但是,它不会检查测试套件包含的源文件的语法错误。PHPUnit的未来版本会用在砂箱中PHP解释器类解决这个问题。