File: Zend_Test-PHPUnit-Db-Testing.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (242 lines) | stat: -rw-r--r-- 10,954 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect2 id="zend.test.phpunit.db.testing">
    <title>Utilisation, API et possibilités d'extension</title>

    <para>
        Le Quickstart permet déja de se rendre compte des capacités de tests d'une base de données avec
        PHPUnit et Zend Framework. Cette section donne un aperçu de l'<acronym>API</acronym> de
        <classname>Zend_Test_PHPUnit_Db</classname> ainsi que de son fonctionnement interne.
    </para>

    <note>
        <title>Remarque sur les tests de bases de données</title>

        <para>
            Tout comme les TestCase de vos contrôleurs, les tests de bases de données sont efféctués
            au niveau intégration. Ils utilisent différentes couches applicatives pour lancer les tests
            et à ce titre devraient être utilisés avec précaution.
        </para>

        <para>
            Notez que tester la logique métier au seul moyen de tests d'intégration comme ceux
            fournis avec Zend_Test de Zend Framework est une mauvaise pratique. Les tests d'intégration
            sont là pour prouver le bon fonctionnement de l'assemblage des composants entre eux, ils ne
            doivent donc pas remplacer des tests unitaires éffectués plus bas dans les couches de votre
            logique métier.
        </para>
    </note>

    <sect3 id="zend.test.phpunit.db.testing.testcase">
        <title>La classe Zend_Test_PHPUnit_DatabaseTestCase</title>

        <para>
            La classe <classname>Zend_Test_PHPUnit_DatabaseTestCase</classname> étend
            <classname>PHPUnit_Extensions_Database_TestCase</classname>, celle-ci permet de configurer
            un jeu de données concernant la base, pour chaque test. L'implementation du Zend Framework
            offre quelques fonctionalités supplémentaires par rapport à l'extension PHPUnit concernant
            les bases de données, ceci dans le but d'utiliser des ressources provenant de
            <classname>Zend_Db</classname>. Voici le scénario classique d'un test de base de données :
        </para>

        <orderedlist>
            <listitem>
                <para>
                    Pour chaque test, PHPUnit crée une instance de la classe de tests (TestCase) et lance
                    la méthode <methodname>setUp()</methodname>.
                </para>
            </listitem>

            <listitem>
                <para>
                    Le scénario de test (TestCase) crée à son tour une instance du testeur de base de données
                    (Database Tester) qui s'occupe de la construction et destruction de la base de données.
                </para>
            </listitem>

            <listitem>
                <para>
                    Le testeur de base de données récupère la connexion à la base et le jeu de données
                    initiales grâce à <methodname>getConnection()</methodname> et
                    <methodname>getDataSet()</methodname> qui sont toutes deux des méthodes abstraites
                    que vous devez implémenter dans votre scénario de test.
                </para>
            </listitem>

            <listitem>
                <para>
                    Par défaut le testeur vide les tables spécifiées dans le jeu de données, puis
                    peuple la base avec le jeu de données.
                </para>
            </listitem>

            <listitem>
                <para>
                    Lorsque le testeur a fini de monter la base, PHPUnit lance votre test.
                </para>
            </listitem>

            <listitem>
                <para>
                    Après que votre test ait fini, <methodname>tearDown()</methodname> est appelée.
                    Cette méthode n'exécute aucune action du la base de données elle-même car les
                    actions à mener sont efféctuées en <methodname>setUp()</methodname> (vider les
                    tables).
                </para>
            </listitem>
        </orderedlist>

        <note>
            <para>
                Le test de la base s'attend à ce que la base de données et les tables soient présentes.
                Il n'existe pas de mécanisme pour créer/détruire des base de données et/ou des tables.
            </para>
        </note>

        <para>
            La classe <classname>Zend_Test_PHPUnit_DatabaseTestCase</classname> permet les tests de base
            de données à l'echelle du Zend Framework.
        </para>

        <para>
            Le tableau suivant liste uniquement les nouvelles méthodes par rapport à la classe
            <classname>PHPUnit_Extensions_Database_TestCase</classname>, dont l'<ulink
                url="http://www.phpunit.de/manual/current/en/database.html">API est documentée dans
                la documentation de PHPUnit</ulink>.
        </para>

        <table id="zend.test.phpunit.db.testing.testcase.api-methods">
            <title>Méthodes de Zend_Test_PHPUnit_DatabaseTestCase</title>

            <tgroup cols="2">
                <thead>
                    <row>
                        <entry>Méthode</entry>
                        <entry>Description</entry>
                    </row>
                </thead>

                <tbody>
                    <row>
                        <entry>
                            <methodname>createZendDbConnection(Zend_Db_Adapter_Abstract $connection,
                                $schema)</methodname>
                        </entry>

                        <entry>
                            Créer une connexion compatible avec l'extension PHPUnit Database depuis une
                            instance de <classname>Zend_Db_Adapter_Abstract</classname>. Cette méthode devrait
                            être utilisée dans la configuration du scénario de tests en implémentant la méthode
                            abstraite <methodname>getConnection()</methodname>.
                        </entry>
                    </row>

                    <row>
                        <entry><methodname>getAdapter()</methodname></entry>

                        <entry>
                            Méthode permettant l'accès à l'instance de
                            <classname>Zend_Db_Adapter_Abstract</classname> qui est encapsulée dans
                            la connexion efféctuée par PHPUnit au moyen de
                            <methodname>getConnection()</methodname>.
                        </entry>
                    </row>

                    <row>
                        <entry>
                            <methodname>createDbRowset(Zend_Db_Table_Rowset_Abstract $rowset,
                                $tableName = null)</methodname>
                        </entry>

                        <entry>
                            Créer un objet représentant les données d'une table depuis une instance de
                            <classname>Zend_Db_Table_Rowset_Abstract</classname> donnée. La table
                            reliée au rowset est choisie lorsque <varname>$tableName</varname>
                            est <constant>NULL</constant>.
                        </entry>
                    </row>

                    <row>
                        <entry>
                            <methodname>createDbTable(Zend_Db_Table_Abstract $table, $where = null,
                                $order = null, $count = null, $offset = null)</methodname>
                        </entry>

                        <entry>
                            Créer un objet qui représente les données contenues dans une instance de
                            <classname>Zend_Db_Table_Abstract</classname> donnée. La récupération des
                            données est faite grâce à <methodname>fetchAll()</methodname>, les paramètres
                            additionnels peuvent servir à limiter les données retournées.
                        </entry>
                    </row>

                    <row>
                        <entry>
                            <methodname>createDbTableDataSet(array $tables=array())</methodname>
                        </entry>

                        <entry>
                            Crée un jeu de données basé sur les tables <varname>$tables</varname>, tableau
                            d'instances de <classname>Zend_Db_Table_Abstract</classname>.
                        </entry>
                    </row>
                </tbody>
            </tgroup>
        </table>
    </sect3>

    <sect3 id="zend.test.phpunit.db.testing.controllerintegration">
        <title>Intégrer les tests de bases de données avec les tests de contrôleurs</title>

        <para>
            <acronym>PHP</acronym> n'autorise pas l'héritage multiple, donc vous ne pouvez utiliser
            les tests de contrôleurs et de bases de données en même temps via héritage. Cependant,
            vous pouvez utiliser <classname>Zend_Test_PHPUnit_Db_SimpleTester</classname> dans vos tests de
            contrôleurs pour configurer un environnement relatif à la base pour chaque test de contrôleur.
        </para>

        <example id="zend.test.phpunit.db.testing.controllerintegration.example">
            <title>Exemple d'intégration d'une base de données</title>

            <para>
                Cet exemple reprend le test de UserController utilisé dans la documentation de
                <classname>Zend_Test_PHPUnit_ControllerTestCase</classname> et y inclut la gestion
                d'une base de données.
            </para>

            <programlisting language="php"><![CDATA[
class UserControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
{
    public function setUp()
    {
        $this->setupDatabase();
        $this->bootstrap = array($this, 'appBootstrap');
        parent::setUp();
    }

    public function setupDatabase()
    {
        $db = Zend_Db::factory(...);
        $connection = new Zend_Test_PHPUnit_Db_Connection($db,
                                                      'database_schema_name');
        $databaseTester = new Zend_Test_PHPUnit_Db_SimpleTester($connection);

        $databaseFixture =
                    new PHPUnit_Extensions_Database_DataSet_FlatXmlDataSet(
                        dirname(__FILE__) . '/_files/initialUserFixture.xml'
                    );

        $databaseTester->setupDatabase($databaseFixture);
    }
}
]]></programlisting>

            <para>
                Ici le jeu de données <acronym>XML</acronym> "initialUserFixture.xml" est utilisé pour monter
                des données en base avant chaque test, exactement de la même manière que DatabaseTestCase le
                fait en interne.
            </para>
        </example>
    </sect3>
</sect2>