unit_testing.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>单元测试类 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/libraries/unit_testing.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  27. <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;单元测试类 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>单元测试类</h1>
  61. <p>单元测试是一种用于测试应用程序中每个函数的软件开发方法。如果你对此概念不熟悉,或许需要google一下相关概念。</p>
  62. <p>CodeIgniter的单元测试类非常简单,由一个评估函数和两个结果函数组成。它没打算成为一个十全的测试集,只提供一个简单的能够评测你的代码是否可以产生正确的数据类型及结果的解决方案。</p>
  63. <h2>初始化单元类</h2>
  64. <p>和大多数其它的类一样,在CodeIgniter中,单元测试类一样要在控制器中用函数<dfn>$this-&gt;load-&gt;library</dfn> 来初始化:</p>
  65. <code>$this-&gt;load-&gt;library('unit_test');</code>
  66. <p>测试类一旦加载,单元测试对象可以这样使用:<dfn>$this-&gt;unit</dfn></p>
  67. <h2>运行测试:</h2>
  68. <p>运行一个测试应提供一个测试及期望的结果给以下函数:</p>
  69. <h2>$this-&gt;unit-&gt;run( <var>test</var>, <var>expected result</var>, '<var>test name</var>', '<var>notes</var>');</h2>
  70. <p>Where <var>test</var> is the result of the code you wish to test, <var>expected result</var> is the data type you expect,
  71. <var>test name</var> is an optional name you can give your test, and <var>notes</var> are optional notes. Example:</p>
  72. <code>$test = 1 + 1;<br />
  73. <br />
  74. $expected_result = 2;<br />
  75. <br />
  76. $test_name = 'Adds one plus one';<br />
  77. <br />
  78. $this-&gt;unit-&gt;run($test, $expected_result, $test_name);</code>
  79. <p>你所给出的期望结果($expected_result)可以是字面上匹配(literal match)的也可以是数据类型上匹配的。下例为字面匹配(literal match):</p>
  80. <code>$this-&gt;unit-&gt;run('Foo', 'Foo');</code>
  81. <p>下例为类型匹配(data type match):</p>
  82. <code>$this-&gt;unit-&gt;run('Foo', 'is_string');</code>
  83. <p>注意第二个参数"is_string"的使用,它告诉函数测试你的测试用例产生的将是一个字符串。下面是合法的类型列表:</p>
  84. <ul>
  85. <li>is_object</li>
  86. <li>is_string</li>
  87. <li>is_bool</li>
  88. <li>is_true</li>
  89. <li>is_false</li>
  90. <li>is_int</li>
  91. <li>is_numeric</li>
  92. <li>is_float</li>
  93. <li>is_double</li>
  94. <li>is_array</li>
  95. <li>is_null</li>
  96. </ul>
  97. <h2>生成报告</h2>
  98. <p>你可以在每个测试后立刻显示结果,也可以运行若干测试后再产生报告。直接显示一个报告,可以用echo或者返回<var>run</var>函数(的执行结果):</p>
  99. <code>echo $this-&gt;unit-&gt;run($test, $expected_result);</code>
  100. <p>显示所有测试的完整的报告,可以这样:</p>
  101. <code>echo $this-&gt;unit-&gt;report();</code>
  102. <p>报告会以格式化了的HTML表格的形式呈现。如果你更喜欢看原始的数据,可以用下面代码获取一个数组:</p>
  103. <code>echo $this-&gt;unit-&gt;result();</code>
  104. <h2>严格模式</h2>
  105. <p>默认情况下,单元测试类评测字面匹配(literal match)时比较宽松,考虑以下例子:</p>
  106. <code>$this-&gt;unit-&gt;run(1, TRUE);</code>
  107. <p>此测试评测的是一个整数,但是期望结果却是布尔值。不过,由于PHP是弱类型语言,使用正常的相等测试,以上代码返回的将是TRUE:</p>
  108. <code>if (1 == TRUE) echo 'This evaluates as true';</code>
  109. <p>喜欢的话,你可以让单元测试类在严格模式下执行,这样它会同时比较两数据的类型及值:</p>
  110. <code>if (1 === TRUE) echo 'This evaluates as FALSE';</code>
  111. <p>启用严格模式:</p>
  112. <code>$this-&gt;unit-&gt;use_strict(TRUE);</code>
  113. <h2>启用/禁用单元测试</h2>
  114. <p>如果你想放一些测试在代码中,而又希望让它只在需要的时候运行,你可以禁用单元测试:</p>
  115. <code>$this-&gt;unit-&gt;active(FALSE)</code>
  116. <h2>Unit Test Display</h2>
  117. <p>When your unit test results display, the following items show by default:</p>
  118. <p><strong>试翻译:</strong>当你显示单元测试结果的时候,以下信息(原以为条目)将被默认显示:</p>
  119. <ul>
  120. <li>Test Name (test_name)</li>
  121. <li><strong>试翻译:</strong>测试名称(test_name)</li>
  122. <li>Test Datatype (test_datatype)</li>
  123. <li><strong>试翻译:</strong>测试数据类型(test_datatype)</li>
  124. <li>Expected Datatype (res_datatype)</li>
  125. <li><strong>试翻译:</strong>期望数据类型(res_datatype)</li>
  126. <li>Result (result)</li>
  127. <li><strong>试翻译:</strong>结果(result)</li>
  128. <li>File Name (file)</li>
  129. <li><strong>试翻译:</strong>文件名称(file)</li>
  130. <li>Line Number (line)</li>
  131. <li><strong>试翻译:</strong>行数(line)</li>
  132. <li>Any notes you entered for the test (notes)</li>
  133. <li><strong>试翻译:</strong>手动添加的注释(notes)</li>
  134. </ul>
  135. <p>You can customize which of these items get displayed by using <kbd>$this-&gt;unit-&gt;set_items()</kbd>. For example, if you only wanted the test name and the result displayed:</p>
  136. <p><strong>试翻译:</strong>使用<kbd>$this-&gt;unit-&gt;set_items()</kbd> ,你可以自定义显示信息(条目). 比如,如果你只期望显示测试名称和测试结果:</p>
  137. <h3>Customizing displayed tests</h3>
  138. <h3><strong>试翻译:</strong>自定义显示测试结果</h3>
  139. <code>
  140. $this-&gt;unit-&gt;set_test_items(array('test_name', 'result'));
  141. </code>
  142. <h3>Creating a Template</h3>
  143. <h3><strong>试翻译:</strong>创建显示模板</h3>
  144. <p>如果你希望测试结果以自定义的格式显示,这里提供一个简单的模板示例。注意必需的伪变量(seudo-variables):</p>
  145. <code>
  146. $str = '<br />
  147. &lt;table border="0" cellpadding="4" cellspacing="1"><br />
  148. &nbsp;&nbsp;&nbsp;&nbsp;<kbd>&#123;rows&#125;</kbd><br />
  149. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;tr><br />
  150. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;td><kbd>&#123;item&#125;</kbd>&lt;/td><br />
  151. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;td><kbd>&#123;result&#125;</kbd>&lt;/td><br />
  152. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;/tr><br />
  153. &nbsp;&nbsp;&nbsp;&nbsp;<kbd>&#123;/rows&#125;</kbd><br />
  154. &lt;/table>';<br />
  155. <br />
  156. $this-&gt;unit-&gt;set_template($str);
  157. </code>
  158. <p class="important"><strong>注意:</strong> 你的模板必须在单元测试运行之前声明。</p><p>&nbsp;</p>
  159. <div id="Contributors">
  160. 翻译贡献者:
  161. Hex, iptton, Jimmy_zZ, zhou78620051</div>
  162. <div id="DocDate">
  163. 最后修改: 2012-06-20 09:21:46</div>
  164. </div>
  165. <!-- END CONTENT -->
  166. <div id="footer">
  167. <p>
  168. 上一个主题:&nbsp;&nbsp;<a href="typography.html">排版类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  169. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="uri.html">URI 类</a> </p>
  170. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  171. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  172. </div>
  173. </body>
  174. </html>