Zend_Test-PHPUnit.xml 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <!-- EN-Revision: 12339 -->
  2. <sect1 id="zend.test.phpunit" xmlns:xi="http://www.w3.org/2001/XInclude">
  3. <title>Zend_Test_PHPUnit</title>
  4. <para><classname>Zend_Test_PHPUnit</classname> fournit un TestCase pour les applications MVC qui contient des assertions qui
  5. permettent de tester toute une variété de responsabilités. La manière la plus facile de comprendre ce qui peut être
  6. fait est de regarder l'exemple suivant.</para>
  7. <example id="zend.test.phpunit.loginexample">
  8. <title>Exemple d'un TestCase d'une application de login</title>
  9. <para>L'exemple suivant est un simple test pour un contrôleur <code>UserController</code> permettant de vérifier
  10. différentes choses :</para>
  11. <itemizedlist>
  12. <listitem>
  13. <para>Le formulaire de login doit être affiché aux utilisateurs non-authentifiés.</para>
  14. </listitem>
  15. <listitem>
  16. <para>Quand un utilisateur se connecte, il doit être redirigé vers sa page de profil, et cette page doit
  17. affichée des infofrmations particulières.</para>
  18. </listitem>
  19. </itemizedlist>
  20. <para>Cet exemple particulier suppose différentes choses. Premièrement, la majeure partie de notre fichier
  21. d'amorçage a été déplacé dans un plugin. Ceci simplifie le paramétrage dans le cas des tests en spécifiant
  22. rapidement votre environnement, et ainsi vous permet d'amorcer votre application en une seule ligne. Ensuite,
  23. notre exemple suppose que le chargement automatique ("autoload") est activé donc nous n'avons pas à nous soucier
  24. de charger les classes appropriées (comme le bon contrôleur, le bon plugin, etc.)</para>
  25. <programlisting role="php"><![CDATA[
  26. class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
  27. {
  28. public function setUp()
  29. {
  30. $this->bootstrap = array($this, 'appBootstrap');
  31. parent::setUp();
  32. }
  33. public function appBootstrap()
  34. {
  35. $this->frontController->registerPlugin(
  36. new Bugapp_Plugin_Initialize('development')
  37. );
  38. }
  39. public function testCallWithoutActionShouldPullFromIndexAction()
  40. {
  41. $this->dispatch('/user');
  42. $this->assertController('user');
  43. $this->assertAction('index');
  44. }
  45. public function testIndexActionShouldContainLoginForm()
  46. {
  47. $this->dispatch('/user');
  48. $this->assertAction('index');
  49. $this->assertQueryCount('form#loginForm', 1);
  50. }
  51. public function testValidLoginShouldGoToProfilePage()
  52. {
  53. $this->request->setMethod('POST')
  54. ->setPost(array(
  55. 'username' => 'foobar',
  56. 'password' => 'foobar'
  57. ));
  58. $this->dispatch('/user/login');
  59. $this->assertRedirectTo('/user/view');
  60. $this->resetRequest()
  61. ->resetResponse();
  62. $this->request->setMethod('GET')
  63. ->setPost(array());
  64. $this->dispatch('/user/view');
  65. $this->assertRoute('default');
  66. $this->assertModule('default');
  67. $this->assertController('user');
  68. $this->assertAction('view');
  69. $this->assertNotRedirect();
  70. $this->assertQuery('dl');
  71. $this->assertQueryContentContains('h2', 'User: foobar');
  72. }
  73. }
  74. ]]></programlisting>
  75. <para>Cet exemple pourrait être écrit plus simplement : toutes les assertions ne sont pas nécessaires et sont
  76. fournies seulement à titre d'illustration. Cependant, il montre bien combien il est simple de tester vos
  77. applications.</para>
  78. </example>
  79. <xi:include href="Zend_Test-PHPUnit-Bootstrapping.xml" />
  80. <xi:include href="Zend_Test-PHPUnit-Testing.xml" />
  81. <xi:include href="Zend_Test-PHPUnit-Assertions.xml" />
  82. <xi:include href="Zend_Test-PHPUnit-Examples.xml" />
  83. </sect1>