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

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

phpunit ArrayTest
PHPUnit 2.3.0 by Sebastian Bergmann.

Time: 0.067288

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

  ·测试成功打印“.”。

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

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

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

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

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

phpunit --help
PHPUnit 2.3.0 by Sebastian Bergmann.

Usage: phpunit [switches] UnitTest [UnitTest.php]
--coverage-data <file> Write code-coverage data in raw format to file.
--coverage-html <file> Write code-coverage data in HTML format to file.
--coverage-text <file> Write code-coverage data in text format to file.
--testdox-html <file> Write agile documentation in HTML format to file.
--testdox-text <file> Write agile documentation in Text format to file.
--log-xml <file> Log test progress in XML format to file.
--loader <loader> TestSuiteLoader implementation to use.
--skeleton Generate skeleton UnitTest class for Unit in Unit.php.
--wait Waits for a keystroke after each test.
--help Prints this usage information.
--version Prints the version and exits.
  phpunit UnitTest

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

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

phpunit UnitTest UnitTest.php

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

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

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

--testdox-html and --testdox-text

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

--log-xml

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

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

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

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

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

  --skeleton

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

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

phpunit --skeleton Sample
PHPUnit 2.3.0 by Sebastian Bergmann.
Wrote test class skeleton for Sample to
SampleTest.php.
phpunit SampleTest
PHPUnit 2.3.0 by Sebastian Bergmann.
I
Time: 0.007268
There was 1 incomplete test case:
1) testSampleMethod(SampleTest)
OK, but incomplete test cases!!!
Tests run: 1, incomplete test cases: 1.
  当你为现有代码书写测试时,你不得不重复很多相同的代码片断,如:

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

--wait

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

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

时间: 2024-12-30 13:29:26

PHPUnit袖珍指南之命令行测试工具的相关文章

PHPUnit的命令行测试工具

PHPUnit命令行测试工具是通过phpunit命令调用的.如下代码显示如何通过PHPUnit命令行测试工具运行测试. phpunit ArrayTest PHPUnit 2.3.0 by Sebastian Bergmann. Time: 0.067288 OK (2 tests) 对每个测试,PHPUnit命令行测试工具打印一个字符表示进程: ·测试成功打印".". ·运行测试方法是发生了断言失败打印"F". ·运行测试方法是发生了错误打印"E&quo

Expect-lite 4.2.0发布 命令行自动化工具

Expect-lite是一个简单快速的命令行自动化工具,其功能是直接映射一个交互式终端到自动化脚本. Expect-lite的脚本在每一行的开头使用特殊字符(S)来指示行动,基本的Expect-lite脚本可以简单地创建剪切和粘贴文本,从一个终端窗口到一个脚本,并加入 '>' '<' 字符.Expect-lite以验证测试环境为目标,在脚本末尾产生一个通过/失败结果,它在此环境中使用不受限制.它包含一个强大的断点.步进/跳过的调试器,能够进行复制/粘贴行到正在运行的脚本. Expect-lit

winsock-如何在本地测试Server/Client程序,UDP和TCP协议,本地需要在命令行测试还是在哪里测试

问题描述 如何在本地测试Server/Client程序,UDP和TCP协议,本地需要在命令行测试还是在哪里测试 写好的程序怎么测试通信是否正常,如何在本地测试Server/Client程序,UDP和TCP协议,本地需要在命令行测试还是在哪里测试 解决方案 可以用命令行执行服务端和客户端,然后打印输出,也可以在局域网内,一台机器跑服务端,一台跑客户端 解决方案二: 直接将客户端和服务器端运行起来,测试下就可以了.

Zoom Profiler 2.1.2发布 图形界面和命令行分析工具

Zoom Profiler 是一个为Linux节省成本的图形界面和命令行分析工具.它主要特点是具有全系统的配置文件,精确的指令级,捕捉完整的C++/C++/ObjC/http://www.aliyun.com/zixun/aggregation/29818.html">Fortran/汇编代码回溯. Zoom Profiler 可以让你看到时间消耗的确切位置,代码运行(用户或内核),以及代码如何调用.它能够保存配置文件作为一个单一的自成体系的session文件,可以通过电子邮件发送或附加到

Zoom Profiler 2.1.1发布 图形界面和命令行分析工具

Zoom Profiler 是一个为Linux节省成本的图形界面和命令行分析工具.它主要特点是具有全系统的配置文件,精确的指令级,捕捉完整的C++/C++/ObjC/http://www.aliyun.com/zixun/aggregation/29818.html">Fortran/汇编代码回溯. Zoom Profiler 可以让你看到时间消耗的确切位置,代码运行(用户或内核),以及代码如何调用.它能够保存配置文件作为一个单一的自成体系的session文件,可以通过电子邮件发送或附加到

Zoom Profiler 2.1.0发布 图形界面和命令行分析工具

Zoom Profiler 是一个为Linux节省成本的图形界面和命令行分析工具.它主要特点是具有全系统的配置文件,精确的指令级,捕捉完整的C++/C++/ObjC/http://www.aliyun.com/zixun/aggregation/29818.html">Fortran/汇编代码回溯. Zoom Profiler 可以让你看到时间消耗的确切位置,代码运行(用户或内核),以及代码如何调用.它能够保存配置文件作为一个单一的自成体系的session文件,可以通过电子邮件发送或附加到

Zoom Profiler 2.0.5发布 图形界面和命令行分析工具

Zoom Profiler是一个为Linux低开销的图形界面和命令行分析工具.配置文件是全系统的,精确的指令级,捕捉完整的C++/C++/ObjC/http://www.aliyun.com/zixun/aggregation/29818.html">Fortran/汇编代码回溯.可以让你看时间的确切位置.代码运行(用户或内核).以及运行如何代码.深度探讨取到一个特定的符号,并放大显示源代码与汇编在一般和特定处理器的优化建议注明.保存的配置文件作为单一的自成体系的session文件,可以通

eclipse-appium怎么通过命令行测试?

问题描述 appium怎么通过命令行测试? 如题,比如我现在有要测试的app和测试文件,怎么在命令行调用appium进行测试? 我不知道appium在哪里指定测试文件的,能不通过eclipse,只是用命令测试吗?谢谢 解决方案 启动appium: appium -a 127.0.0.1 -p 4723 -U UDID --no-reset 其中UDID 可用adb devices获取 然后运行你要执行的脚本,这个根据脚本语言不同执行命令也不同

Taskwarrior:Linux下一个很棒的命令行TODO工具

Taskwarrior 是 Ubuntu/Linux 下一个简单而直接的基于命令行的 TODO 工具.这个开源软件是我曾用过的最简单的基于命令行的工具之一.Taskwarrior 可以帮助你更好地组织你自己,而不用安装笨重的新工具--这有时丧失了 TODO 工具的目的. Taskwarrior:一个基于简单的基于命令行帮助完成任务的TODO工具 Taskwarrior是一个开源.跨平台.基于命令行的 TODO 工具,它帮你在终端中管理你的 to-do 列表.这个工具让你可以轻松地添加任务.展示列