Heim  >  Artikel  >  Backend-Entwicklung  >  Yii Framework Offizieller Leitfaden Serie 38 – Definieren spezifischer Zustände (Fixtures)

Yii Framework Offizieller Leitfaden Serie 38 – Definieren spezifischer Zustände (Fixtures)

黄舟
黄舟Original
2017-02-15 09:43:481275Durchsuche



Automatisierte Tests müssen viele Male ausgeführt werden. Um sicherzustellen, dass der Testprozess wiederholbar ist, möchten wir wirklich in einigen bekannten Zuständen testen , wir nennen diesen Zustand Spezifischer Zustand. Wenn wir beispielsweise die Artikelerstellungsfunktion in einer Blog-Anwendung testen, wird bei jeder Durchführung des Tests die Tabelle zum Artikel angezeigt (z. B. Post Tabelle , Comment Tabelle) sollte in einem bestimmten Zustand wiederhergestellt werden. Die PHPUnit-Dokumentation enthält eine gute Beschreibung des allgemeinen Aufbaus eines bestimmten Zustands. In diesem Abschnitt wird hauptsächlich beschrieben, wie ein datenbankspezifischer Zustand wie im gerade beschriebenen Beispiel erstellt wird

Das Festlegen des spezifischen Status der erstellten Datenbank ist wahrscheinlich einer der zeitaufwändigsten Teile beim Testen von Anwendungen mit Datenbank-Backend-Unterstützung. Die von Yii eingeführte Anwendungskomponente CBbFixtureManager kann dieses Problem bei der Durchführung einer Reihe von Tests effektiv lindern Im Wesentlichen geschieht Folgendes:

  • Bevor alle Tests ausgeführt werden, werden testbezogene Daten auf einen erkennbaren Zustand zurückgesetzt

  • Vor einem einzelnen Test Wenn es ausgeführt wird, wird eine bestimmte Tabelle auf einen bekannten Status zurückgesetzt.

  • Während der Ausführung einer Testmethode bietet es eine Möglichkeit, Datenzeilen in einem bestimmten Status bereitzustellen.

Bitte verwenden Sie den CDbFixtureManager, den wir in der Anwendungskonfiguration wie folgt konfiguriert haben.


return array(
    'components'=>array(
        'fixture'=>array(
            'class'=>'system.test.CDbFixtureManager',
        ),
    ),
);

Dann stellen wir bestimmte Statusdaten im Verzeichnis

bereit, indem wir das Attribut CDbFixtureManager::basePath in der Anwendungskonfigurationsdatei konfigurieren ist eine Kombination aus PHP-Dateien spezifischer Statusdateien. Jede spezifische Statusdatei gibt die erste Zeile einer bestimmten Datentabelle zurück. Der Dateiname und der Tabellenname sind identisch protected/tests/fixtures Tabellenbeispiel in einer Datei mit dem Namen Post.Post.php


<?php
return array(
    &#39;sample1&#39;=>array(
        'title'=>'test post 1',
        'content'=>'test post content 1',
        'createTime'=>1230952187,
        'authorId'=>1,
    ),
    'sample2'=>array(
        'title'=>'test post 2',
        'content'=>'test post content 2',
        'createTime'=>1230952287,
        'authorId'=>1,
    ),
);

Wie wir sehen können, das Obige gibt zwei Zeilendaten zurück. Jede Zeile stellt ein Array dar, der Schlüssel ist der Feldname der Tabelle und der Wert ist der entsprechende Feldwert. Der Index jeder Zeile ist eine Zeichenfolge mit dem Namen

Zeilenalias (z. B : , simple1). dass wir den Wert des Felds simple2 im obigen spezifischen Zustand nicht angegeben haben. Dies liegt daran, dass das Feld

als automatisch inkrementierender Primärschlüssel definiert wurde und sein Wert auch automatisch generiert wird, wenn wir einen neuen Schlüssel einfügen data.

idWenn CDbFixtureManager zum ersten Mal referenziert wird, prüft er sorgfältig alle spezifischen Statusdateien und verwendet sie dann zum Zurücksetzen der entsprechenden Tabelle. Er löscht die Tabelle und setzt den Wert der automatischen Inkrementierungssequenz zurück Primärschlüssel der Tabelle und fügt dann den Wert aus „Zurücksetzen der Tabelle“ ein, indem Datenzeilen aus einer bestimmten Statusdatei in die Tabelle eingefügt werden.id

Manchmal möchten wir möglicherweise nicht jede zuvor in einer bestimmten Statusdatei beschriebene Tabelle zurücksetzen Eine Reihe von Tests, da das Zurücksetzen zu vieler spezifischer Statusdateien viel Zeit in Anspruch nehmen kann. In diesem Fall können wir ein PHP-Skript schreiben, um diesen Initialisierungsprozess anzupassen. Dieses Skript sollte in dem Verzeichnis gespeichert werden, in dem sich die spezifische Statusdatei befindet gespeichert und mit dem Namen

versehen. Wenn CDbFixtureManager dies erkennt, führt es dieses Skript aus, anstatt jede Tabelle zurückzusetzen.

Es ist in Ordnung, wenn Sie nicht die Standardmethode zum Zurücksetzen verwenden möchten Tabelle, zum Beispiel: Löschen Sie die Tabelle und fügen Sie dann bestimmte Statusdaten ein. In diesem Fall können wir ein Initialisierungsskript für die angegebene spezifische Statusdatei schreiben. Dieses Skript muss Tabellenname + init.php heißen. Die Initialisierungsskriptdatei der Tabelle

ist

. Wenn CDbFixtureManager dieses Skript findet, wird dieses Skript ausgeführt, anstatt die Tabelle auf die Standardmethode zurückzusetzen..init.phpPostPost.init.php

Tipp :
Zu viele zustandsspezifische Dateien verlängern die Testzeit erheblich. Daher sollten Sie nur bestimmte Zustandsdateien für Tabellen bereitstellen, deren Daten sich während des Tests ändern. Tabellen, die als Suchdienste dienen, ändern sich also nicht benötigt.

In den nächsten beiden Abschnitten werden wir darüber sprechen, wie bestimmte von CDbFixtureManager verwaltete Zustände in Komponententests und Funktionstests verwendet werden.

Das Obige ist der Inhalt von Yii Framework Offizielle Leitfadenreihe 38 – Definieren spezifischer Zustände (Fixtures). Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn