Zend_Test-PHPUnit-Bootstrapping.xml 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 18222 -->
  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. <code>PHPUnit_Framework_TestCase</code> を継承しており、
  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. そうすると、そのファイルはフロントコントローラをディスパッチせず、
  25. 単にフロントコントローラ (とアプリケーション固有の設定)
  26. を準備するだけの役割となります。
  27. </para>
  28. <programlisting language="php"><![CDATA[
  29. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  30. {
  31. public $bootstrap = '/path/to/bootstrap/file.php'
  32. // ...
  33. }
  34. ]]></programlisting>
  35. <para>
  36. 2 番目の方法として、アプリケーションを起動するための
  37. <acronym>PHP</acronym> コールバックを指定することができます。
  38. この方法は <link
  39. linkend="zend.test.phpunit.loginexample">Login サンプル</link>
  40. で使用しています。使用するコールバックが関数や static
  41. メソッドである場合は、クラスレベルで設定することができます。
  42. </para>
  43. <programlisting language="php"><![CDATA[
  44. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  45. {
  46. public $bootstrap = array('App', 'bootstrap');
  47. // ...
  48. }
  49. ]]></programlisting>
  50. <para>
  51. オブジェクトのインスタンスが必要な場合は、
  52. <methodname>setUp()</methodname> メソッドを利用することを推奨します。
  53. </para>
  54. <programlisting language="php"><![CDATA[
  55. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  56. {
  57. public function setUp()
  58. {
  59. // Bootstrap オブジェクトのインスタンスメソッド 'start' を使用します
  60. $bootstrap = new Bootstrap('test');
  61. $this->bootstrap = array($bootstrap, 'start');
  62. parent::setUp();
  63. }
  64. }
  65. ]]></programlisting>
  66. <para>
  67. <methodname>parent::setUp()</methodname>; に注目しましょう。
  68. これは必須です。とうのも、<classname>Zend_Test_PHPUnit_ControllerTestCase</classname>
  69. の <methodname>setUp()</methodname> メソッドが残りの起動処理
  70. (コールバックの呼び出しも含む) を実行するからです。
  71. </para>
  72. <para>
  73. 通常、<methodname>setUp()</methodname> メソッドは次のようにアプリケーションを起動します。
  74. まずクリーンな環境を読み込んでリクエストの状態を初期化し、
  75. プラグインやヘルパーをすべてリセットし、
  76. フロントコントローラをリセットして
  77. リクエストオブジェクトとレスポンスオブジェクトを新しく作成します。
  78. それが終わったら、<code>$bootstrap</code>
  79. で指定したファイルを読み込むか、
  80. あるいは指定したコールバックを呼び出します。
  81. </para>
  82. <para>
  83. テストの起動処理は、可能な限りそのアプリケーションの起動処理と同じになるようにしています。
  84. しかし、いくつかの制約もあります。
  85. </para>
  86. <itemizedlist>
  87. <listitem><para>
  88. リクエストオブジェクトやレスポンスオブジェクトに独自実装を用意しても、
  89. それが使われることはありません。
  90. <classname>Zend_Test_PHPUnit_ControllerTestCase</classname> は、
  91. 独自のリクエストオブジェクトとレスポンスオブジェクト (それぞれ
  92. <classname>Zend_Controller_Request_HttpTestCase</classname> および
  93. <classname>Zend_Controller_Response_HttpTestCase</classname>)
  94. を持っています。これらのオブジェクトには、
  95. 指定した方法でリクエスト環境を準備したり
  96. 指定した方法で人工的なレスポンスを返したりするメソッドが用意されています。
  97. </para></listitem>
  98. <listitem><para>
  99. テストサーバに特定の設定を期待してはいけません。
  100. 言い換えると、テストの実行環境が特定のサーバ設定になっていることは保証されていないということです。
  101. アプリケーション側から期待してもかまわないのは、
  102. 単にルータがリクエストをルーティングしてくれるということだけです。
  103. サーバ固有のヘッダをリクエストオブジェクトに含めてはいけません。
  104. </para></listitem>
  105. </itemizedlist>
  106. <para>
  107. アプリケーションが起動したら、
  108. いよいよテストを作り始めることができます。
  109. </para>
  110. </sect2>
  111. <!--
  112. vim:se ts=4 sw=4 et:
  113. -->