Heim >Backend-Entwicklung >PHP-Tutorial >Yii Framework Official Guide Series Supplement 40 – Testen: Funktionstests

Yii Framework Official Guide Series Supplement 40 – Testen: Funktionstests

黄舟
黄舟Original
2017-02-16 09:13:331117Durchsuche



Bevor Sie dieses Kapitel lesen, wird dringend empfohlen, die Selenium-Dokumentation und die PHPUnit-Dokumentation zu lesen. Nachfolgend geben wir einen kurzen Überblick über die Schreibfunktion Tests im Yii-Framework Grundprinzipien:

  • Funktionstests werden wie Unit-Tests in Form von XyzTest-Klassen geschrieben, die von CWebTestCase erben, wobei Xyz die zu testende Klasse darstellt PHPUnit_Extensions_SeleniumTestCase ist die Vorfahrenklasse von CWebTestCase, wir können alle Methoden von dieser Klasse erben.

  • Funktionstestklasse wird in der PHP-Datei in Form von XyzTest.php gespeichert Dateien werden normalerweise in protected/tests/functional文件夹下 gespeichert.

  • Die Testklasse enthält hauptsächlich eine Reihe von Testmethoden mit dem Namen testAbc, wobei Abc normalerweise der Name der zu testenden Funktion ist, z Wenn Sie beispielsweise die Benutzeranmeldefunktion testen möchten, verfügen wir möglicherweise über eine Testmethode namens testLogin的测试方法.

  • , die eine Reihe von Befehlsanweisungen zum Testen der Interaktion zwischen Selenium RC und dem Web enthält Sie enthält auch Assertionsanweisungen, die zur Bestätigung der von der Webanwendung erwarteten Antwort verwendet werden.

Bevor wir beschreiben, wie ein Funktionstest geschrieben wird, werfen wir einen Blick auf die Datei WebTestCase.php automatisch durch den Befehl yiic webapp generiert. Diese Datei definiert die Basisklasse für alle Funktionstestklassen WebTestCase:

define('TEST_BASE_URL','http://localhost/yii/demos/blog/index-test.php/');

class WebTestCase extends CWebTestCase
{
    /**
     * Sets up before each test method runs.
     * This mainly sets the base URL for the test application.
     */
    protected function setUp()
    {
        parent::setUp();
        $this->setBrowserUrl(TEST_BASE_URL);
    }

    ......
}

WebTestCase legt hauptsächlich die Stamm-URL der Testseite fest gefolgt von In der Testmethode können wir relative URLs verwenden, um die zu testende Seite anzugeben.

Wir müssen auch beachten, dass in der Test-Root-URL index-test.php als Eingabeskript anstelle von index.php verwendet wird. Der einzige Unterschied zwischen den beiden besteht darin, dass ersteres test.php als Anwendung verwendet Konfigurationsdatei, und dann Der Autor verwendet main.php.

Jetzt beginnen wir mit dem Testen der Funktionsfunktion zum Anzeigen eines Artikels in der Blog-Demo. Schreiben Sie zunächst die Testklasse wie geschrieben Die Testklasse erbt von dem, was wir oben gesagt haben. Die oben erwähnte Basisklasse WebTestCase:

class PostTest extends WebTestCase
{
    public $fixtures=array(
        'posts'=>'Post',
    );

    public function testShow()
    {
        $this->open('post/1');
        // verify the sample post title exists
        $this->assertTextPresent($this->posts['sample1']['title']);
        // verify comment form exists
        $this->assertTextPresent('Leave a Comment');
    }

    ......
}

Genau wie beim Schreiben von Unit-Tests deklarieren wir zunächst die spezifischen Zustände ( Hier geben wir die Verwendung von Post Fixture an. In der testShow-Testmethode verwenden wir zunächst Selenium RC, um die URL post/1 zu öffnen Die URL wird mit der Stamm-URL in der Basisklasse gespleißt (d. h. http://www.php.cn/). Anschließend überprüfen wir, ob der Titel des Beitrags sample1 auf der aktuellen Seite zu finden ist. Wir können auch überprüfen, ob diese Seite den Text .Leave a Comment

Tipp: in Bevor Funktionstests ausgeführt werden, muss zunächst der Selenium-RC-Server gestartet werden. Dies kann durch Ausführen des Befehls in Ihrem Selenium-Server-Installationsverzeichnis. java -jar selenium-server.jar

Das Obige ist der Inhalt von Yii Framework Official Guide Series Supplement 40 – Testing: Functional Testing 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