SimpleTest 1.0.1 を使用して、CakePHP (リリースされたばかりの 1.2.4) で新しいアプリケーションを作成しています。私はクックブックの関連セクションを読み、ベーカリーで検索し、コントローラーのテストに関するマークストーリーの投稿を読みました(難しい方法とモックを使用)。
残念ながら、これは重要なコントローラーの実際のテストについては言及していません。多くのアプリがログインの背後にあるサイトの領域を配置していますが、次の単純なシナリオをテストする方法がわかりません。
- 保護されたページのリダイレクトへのゲスト アクセス?
- 有効な資格情報は、期待されるセッション変数を設定しますか?
- 無効な認証情報によりログイン ページが再表示され、エラー メッセージが表示されますか?
以下のコントローラーとテストは、思ったように機能しません。両方のアサーションが失敗し、PHP エラーも発生します。
FAILED [NULL] は [.../app/tests/cases/controllers/users_controller.test.php 行 79] で null であってはなりません .../app/tests/cases/controllers/users_controller.test.php -> UsersControllerTest -> テストログイン
[.../app/tests/cases/controllers/users_controller.test.php 行 80] .../app/tests/cases/controllers/ で [NULL] が [整数: 1] と一致しないため、失敗しました。 users_controller.test.php -> UsersControllerTest -> testLogin
エラー予期しない PHP エラー [未定義のインデックス: アクション] 重大度 [E_NOTICE] in [.../cake/libs/controller/components/auth.php 行 266] .../app/tests/cases/controllers/users_controller.test. php -> UsersControllerTest -> testLogin
これがコントローラーです(ベイクされたものとMark Storyの「ハードウェイ」テスト方法):
class UsersController extends AppController
{
var $name = 'Users';
var $helpers = array('Html', 'Form');
var $components = array('Auth');
function login()
{
}
function logout()
{
$this->redirect($this->Auth->logout());
}
function index()
{
$this->set('users', $this->paginate());
}
function view($id = null)
{
if (!$id)
{
$this->Session->setFlash(__('Invalid User.', true));
$this->redirect(array('action'=>'index'));
}
$this->set('user', $this->User->read(null, $id));
}
function add()
{
if (!empty($this->data))
{
$this->User->create();
if ($this->User->save($this->data))
{
$this->Session->setFlash(__('The User has been saved', true));
$this->redirect(array('action'=>'index'));
}
else
{
$this->Session->setFlash(__('The User could not be saved. Please, try again.', true));
}
}
}
function edit($id = null)
{
if (!$id && empty($this->data))
{
$this->Session->setFlash(__('Invalid User', true));
$this->redirect(array('action'=>'index'));
}
if (!empty($this->data))
{
if ($this->User->save($this->data))
{
$this->Session->setFlash(__('The User has been saved', true));
$this->redirect(array('action'=>'index'));
}
else
{
$this->Session->setFlash(__('The User could not be saved. Please, try again.', true));
}
}
if (empty($this->data))
{
$this->data = $this->User->read(null, $id);
}
}
function delete($id = null)
{
if (!$id)
{
$this->Session->setFlash(__('Invalid id for User', true));
$this->redirect(array('action'=>'index'));
}
if ($this->User->del($id))
{
$this->Session->setFlash(__('User deleted', true));
$this->redirect(array('action'=>'index'));
}
}
}
テストは次のとおりです。
/* SVN FILE: $Id$ */
/* UsersController Test cases generated on: 2009-08-05 17:08:03 : 1249507923*/
App::import('Controller', 'Users');
class TestUsers extends UsersController
{
var $autoRender = false;
var $redirectUrl;
var $redirectStatus;
var $renderedAction;
var $renderedLayout;
var $renderedFile;
var $stopped;
function redirect($url, $status = null, $exit = true)
{
$this->redirectUrl = $url;
$this->redirectStatus = $status;
}
function render($action = null, $layout = null, $file = null)
{
$this->renderedAction = $action;
$this->renderedLayout = (is_null($layout) ? $this->layout : $layout);
$this->renderedFile = $file;
}
function _stop($status = 0)
{
$this->stopped = $status;
}
}
class UsersControllerTest extends CakeTestCase
{
var $fixtures = array('user');
var $Users = null;
function startTest()
{
$this->Users = new TestUsers();
$this->Users->constructClasses();
$this->Users->Component->initialize($this->Users);
}
function prepareForAction()
{
$this->Users->beforeFilter();
$this->Users->Component->startup($this->Users);
}
function endTest()
{
$this->Users->Session->destroy();
unset($this->Users);
ClassRegistry::flush();
}
//-----------------------------------------------------------------------
function testUsersControllerInstance()
{
$this->assertTrue(is_a($this->Users, 'UsersController'));
}
function testLogin()
{
$this->Users->data = array(
'User' => array(
'username' => 'admin',
'password' => 'admin'
)
);
$this->prepareForAction();
$this->Users->login();
$this->assertNotNull($this->Users->redirectUrl);
$this->assertEqual($this->Users->Session->read('Auth.User.id'), 1);
}
}