FrontPage  Index  Search  Changes  Atom  PageRank  Login

Hikidashi - Hiki on Rack - Zend Frameworkでのユニットテスト Diff

  • Added parts are displayed like this.
  • Deleted parts are displayed like this.

! Zend Frameworkでのユニットテスト
Zend Frameworkでユニットテストを始める方法、詰まりZend_Testコンポーネントの使い方です。
確認した環境は
* Ubuntu 10.04 Desktop 64bit
* Apache 2.2
* PHP 5.3.2
* Zend Framwork 1.10.0
です。

取り敢えずZend Frameworkをインストールしたならzfコマンドが使える筈なので、好きなディレクトリーで
<<<sh
zf create project MyApp
>>>
として、プロジェクト用のディレクトリーを作りましょう。{{br}}
そんで、Apacheの設定をして、MyApp/publicが公開ディレクトリーになるようにしてください。

localhostにアクセスしてこんな画面が表示されるようにしたところからスタートです。
{{attach_view(Zend-Framework-default-index.png)}}

! PHPUnitのインストール
PHPUnitをインストールしてください。[[公式サイト|http://www.phpunit.de/manual/3.6/ja/installation.html]]に方法が載っていますし、UbuntuならSynaptic(つまりapt)からインストールできます。

! PHPUnitのブートストラップの設定
プロジェクトディレクトリーに、testsがあって、その中にphpunit.xmlというファイルがある筈です。これを開いて次のように書き込んでください。
<<< XML
<phpunit bootstrap="test_helper.php"
         colors="true">
</phpunit>
>>>
test_helper.phpはこれから作るファイルなので、任意の名前でOKです。colors="true"は、テスト結果に色を着けてくれるオプションです。{{br}}
その他色々なオプションやら要素やらを書き加えられます。[[PHPUnitのサイトのドキュメント|http://www.phpunit.de/manual/3.6/ja/appendixes.configuration.html]]を参照してください。

これで、testsディレクトリーからphpunitコマンドを実行する時に、test_helper.phpを読み込むようになります。詰まりここでテストの初期化の処理を書けばいいわけです。ファイルを作ってこうします。
<<< PHP
<?php
// Define path to application directory
defined('APPLICATION_PATH')
    || define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/../application'));

// Define application environment
defined('APPLICATION_ENV')
    || define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'development'));

define('APPLICATION_TEST_BOOTSTRAP_PATH', realpath(dirname(__FILE___) . '/application/bootstrap.php'));
define('LIBRARY_TEST_BOOTSTRAP_PATH', realpath(dirname(__FILE___) . '/library/bootstrap.php'));

set_include_path(
     APPLICATION_PATH . '/../library' . PATH_SEPARATOR .
     APPLICATION_PATH . '/controllers' . PATH_SEPARATOR .
     APPLICATION_PATH . '/models' . PATH_SEPARATOR .
     get_include_path()
);

require_once 'Zend/Loader/Autoloader.php';
$autoloader = Zend_Loader_Autoloader::getInstance();
$autoloader->setFallbackAutoloader(TRUE);
>>>
前半はpublic/index.phpにあったのをそのまま持って来ています。

! Zend_Test_PHPUnitのブートストラップの設定
tests/application/bootstrap.phpに、アプリケーションのテストの初期化設定を書きます(他にライブラリーの初期化設定を書くファイルとしてtests/library/bootstrap.phpがあります)。
<<< PHP
<?php
$this->bootstrap = new Zend_Application(
                       APPLICATION_ENV,
                       APPLICATION_PATH . '/configs/application.ini'
                   );
$this->bootstrap();
$this->_frontController = $this->bootstrap->getBootstrap()->getResource('frontcontroller');
>>>

! テストを書く
これで、テストを書く準備ができました。試しにtests/applicadtion/IndexControllerTest.phpをこういう風に作ってみてください。
<<< PHP
<?php

require_once dirname(__FILE__) . '/../test_helper.php';

class IndexControllerTest extends Zend_Test_PHPUnit_ControllerTestCase
{
    public $bootstrap = APPLICATION_TEST_BOOTSTRAP_PATH;
    
    public function testIndex()
    {
        $this->dispatch('/');
        $this->assertQuery('div#welcome');
        $this->assertQuery('div.welcome');
    }
}
>>>
テストケースクラスのbootstrapプロパティに、''フルパスで''さっき書いたbootstrap.phpファイルの場所を入れるのがポイントです。

そして、phpunitコマンドを実行します。
<<< sh
cd ~/MyApp/tests
phpunit application/IndexControllerTest
>>>
こんな感じで結果が出る筈です(赤色が着くと思います)。
<<< sh
PHPUnit 3.4.5 by Sebastian Bergmann.

F

Time: 1 second, Memory: 11.50Mb

There was 1 failure:

1) IndexControllerTest::testIndex
Failed asserting node DENOTED BY div.welcome EXISTS

/usr/share/php/Zend/Test/PHPUnit/Constraint/DomQuery.php:256
/usr/share/php/Zend/Test/PHPUnit/ControllerTestCase.php:291
/home/user/MyApp/tests/application/IndexControllerTest.php:13

FAILURES!
Tests: 1, Assertions: 2, Failures: 1.
>>>
二つのアサーションのうち、一つが失敗していることを意味します。div.welcomeがある筈だけど無いよ、って言われています。div#welcomeは、ある筈で実際あったので何も言われていません。

あとは、[[Zend_Testのドキュメント|http://framework.zend.com/manual/ja/zend.test.html]]を見ながらテストを書いていけばオッケーです。


! あれ
こういうのってユニットテストって言うんだっけ?