phpunit UnitTest UnitTest.php
運(yùn)行類UnitTest提供的測試,該類要定義在命令指定的源文件(UnitTest.php)中。
--coverage-data, --coverage-html, and --coverage-text
控制運(yùn)行測試的代碼覆蓋信息的分析和集合(參見本書后代碼覆蓋分析一節(jié))
--testdox-html and --testdox-text
以HTML或普通文本格式生成運(yùn)行測試的敏捷文檔(參見本書后的“測試的其他用途”一章)
--log-xml
生成運(yùn)行測試的XML格式的日志文件。
下一個(gè)例子顯示為ArrayTest中的測試生成的XML日志文件。
<?xml version="1.0" encoding="UTF-8"?>
<testsuites>
<testsuite name="ArrayTest" tests="2" failures="0" errors="0" time="0.020026">
。紅estcase name="testNewArrayIsEmpty" class="ArrayTest" time="0.014449"/>
。紅estcase name="testArrayContainsAnElement" class="ArrayTest" time="0.005577"/>
</testsuite>
</testsuites>
下面的XML日志文件是為名為FailureErrorTest的測試類兩個(gè)測試生成的,一個(gè)是testFailure,一個(gè)是testError。這顯示了失敗和錯(cuò)誤是如何分別表示的。
<?xml version="1.0" encoding="UTF-8"?>
<testsuites>
<testsuite name="FailureErrorTest" tests="2" failures="1" errors="1" time="0.013603">
。紅estcase name="testFailure" class="FailureErrorTest" time="0.011872">
。糵ailure message="" type="PHPUnit2_Framework_AssertionFailedError"></failure>
</testcase>
<testcase name="testError" class="FailureErrorTest" time="0.001731">
。糴rror message="" type="Exception"></error>
</testcase>
</testsuite>
</testsuites>
--loader
指定將要使用的測試套件加載器。
標(biāo)準(zhǔn)測試套件加載器會(huì)在當(dāng)前工作目錄和PHP的include_path configuration指令定義的路徑中尋找源文件。按照PEAR的命名規(guī)則,形如Project_Package_Class的類名會(huì)映射到的源文件為Project/Package/Class.php。
--skeleton
為類Unit(在文件Unit.php中)生成一個(gè)名為UnitTest(在文件UnitTest.php中)的測試用例類的框架。對原始類的每個(gè)方法,在生成的測試用例類中提供了一個(gè)未完成的測試用例(見本書后的“未完成測試”部分)。
下面的例子顯示了如何為一個(gè)名為Sample的類生成一個(gè)測試類的框架。
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.
當(dāng)你為現(xiàn)有代碼書寫測試時(shí),你不得不重復(fù)很多相同的代碼片斷,如:
public function testSampleMethod( ) {}
PHPUnit能幫助你分析現(xiàn)有代碼,生成測試用例類的框架。
--wait
每個(gè)測試結(jié)束時(shí),等待一次擊鍵。這很有用,特別是你在一個(gè)只有測試一直運(yùn)行在打開的窗口中運(yùn)行測試時(shí)。
提示 當(dāng)被測試代碼中有PHP語法錯(cuò)誤時(shí),文本界面的測試會(huì)直接退出,不輸出任何錯(cuò)誤信息。標(biāo)準(zhǔn)的測試套件加載器會(huì)檢查測試套件的源文件的PHP語法錯(cuò)誤,但是,它不會(huì)檢查測試套件包含的源文件的語法錯(cuò)誤。PHPUnit的未來版本會(huì)用在砂箱中PHP解釋器類解決這個(gè)問題。