Zend_Test-PHPUnit-Bootstrapping.xml 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect2 id="zend.test.phpunit.bootstrapping">
  5. <title>テストケースの起動</title>
  6. <para>
  7. <link linkend="zend.test.phpunit.loginexample">Login
  8. サンプル</link> で説明したように、すべての <acronym>MVC</acronym>
  9. テストケースは
  10. <classname>Zend_Test_PHPUnit_ControllerTestCase</classname>
  11. を継承しなければなりません。このクラスは
  12. <classname>PHPUnit_Framework_TestCase</classname> を継承しており、
  13. PHPUnit が提供する仕組みやアサーションをすべて使用できます。
  14. またそれに加えて、Zend Framework の
  15. <acronym>MVC</acronym> 実装に特化した scaffold 機能やアサーションもあります。
  16. </para>
  17. <para>
  18. <acronym>MVC</acronym> アプリケーションをテストするには、まずそれを起動する必要があります。
  19. いくつかの方法がありますが、どの方法になるかは public プロパティ
  20. <code>$bootstrap</code> で決まります。
  21. </para>
  22. <para>
  23. 最初に、そして、おそらく最も直接的には、
  24. 単純に <filename>index.php</filename> で行うように
  25. <classname>Zend_Application</classname> インスタンスを作成します。
  26. そして、それを <varname>$bootstrap</varname> プロパティにアサインします。
  27. 一般的に、これは <methodname>setUp()</methodname> で行います。
  28. 実行されるときに、 <methodname>parent::setUp()</methodname> を呼ぶ必要があります。
  29. </para>
  30. <programlisting language="php"><![CDATA[
  31. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  32. {
  33. public function setUp()
  34. {
  35. //1段階でアサインしてインスタンス化します。
  36. $this->bootstrap = new Zend_Application(
  37. 'testing',
  38. APPLICATION_PATH . '/configs/application.ini'
  39. );
  40. parent::setUp();
  41. }
  42. }
  43. ]]></programlisting>
  44. <para>
  45. 次に、このプロパティでファイルを指定できます。
  46. そうすると、そのファイルはフロントコントローラをディスパッチせず、
  47. 単にフロントコントローラ (とアプリケーション固有の設定)
  48. を準備するだけの役割となります。
  49. </para>
  50. <programlisting language="php"><![CDATA[
  51. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  52. {
  53. public $bootstrap = '/path/to/bootstrap/file.php'
  54. // ...
  55. }
  56. ]]></programlisting>
  57. <para>
  58. 3番目の方法として、アプリケーションを起動するための
  59. <acronym>PHP</acronym> コールバックを指定できます。
  60. この方法は <link
  61. linkend="zend.test.phpunit.loginexample">Login サンプル</link>
  62. で使用しています。使用するコールバックが関数や static
  63. メソッドである場合は、クラスレベルで設定できます。
  64. </para>
  65. <programlisting language="php"><![CDATA[
  66. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  67. {
  68. public $bootstrap = array('App', 'bootstrap');
  69. // ...
  70. }
  71. ]]></programlisting>
  72. <para>
  73. オブジェクトのインスタンスが必要な場合は、
  74. <methodname>setUp()</methodname> メソッドを利用することを推奨します。
  75. </para>
  76. <programlisting language="php"><![CDATA[
  77. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  78. {
  79. public function setUp()
  80. {
  81. // Bootstrap オブジェクトのインスタンスメソッド 'start' を使用します
  82. $bootstrap = new Bootstrap('test');
  83. $this->bootstrap = array($bootstrap, 'start');
  84. parent::setUp();
  85. }
  86. }
  87. ]]></programlisting>
  88. <para>
  89. <methodname>parent::setUp()</methodname>; に注目しましょう。
  90. これは必須です。とうのも、<classname>Zend_Test_PHPUnit_ControllerTestCase</classname>
  91. の <methodname>setUp()</methodname> メソッドが残りの起動処理
  92. (コールバックの呼び出しも含む) を実行するからです。
  93. </para>
  94. <para>
  95. 通常、<methodname>setUp()</methodname> メソッドは次のようにアプリケーションを起動します。
  96. まずクリーンな環境を読み込んでリクエストの状態を初期化し、
  97. プラグインやヘルパーをすべてリセットし、
  98. フロントコントローラをリセットして
  99. リクエストオブジェクトとレスポンスオブジェクトを新しく作成します。
  100. それが終わったら、<varname>$bootstrap</varname>
  101. で指定したファイルを <methodname>include()</methodname> するか、
  102. あるいは指定したコールバックを呼び出します。
  103. </para>
  104. <para>
  105. テストの起動処理は、可能な限りそのアプリケーションの起動処理と同じになるようにしています。
  106. しかし、いくつかの制約もあります。
  107. </para>
  108. <itemizedlist>
  109. <listitem><para>
  110. リクエストオブジェクトやレスポンスオブジェクトに独自実装を用意しても、
  111. それが使われることはありません。
  112. <classname>Zend_Test_PHPUnit_ControllerTestCase</classname> は、
  113. 独自のリクエストオブジェクトとレスポンスオブジェクト (それぞれ
  114. <classname>Zend_Controller_Request_HttpTestCase</classname> および
  115. <classname>Zend_Controller_Response_HttpTestCase</classname>)
  116. を持っています。これらのオブジェクトには、
  117. 指定した方法でリクエスト環境を準備したり
  118. 指定した方法で人工的なレスポンスを返したりするメソッドが用意されています。
  119. </para></listitem>
  120. <listitem><para>
  121. テストサーバに特定の設定を期待してはいけません。
  122. 言い換えると、テストの実行環境が特定のサーバ設定になっていることは保証されていないということです。
  123. アプリケーション側から期待してもかまわないのは、
  124. 単にルータがリクエストをルーティングしてくれるということだけです。
  125. サーバ固有のヘッダをリクエストオブジェクトに含めてはいけません。
  126. </para></listitem>
  127. </itemizedlist>
  128. <para>
  129. アプリケーションが起動したら、
  130. いよいよテストを作り始めることができます。
  131. </para>
  132. </sect2>
  133. <!--
  134. vim:se ts=4 sw=4 et:
  135. -->