2012-06-18 45 views
3

我想在我的UsersController.php测试登录()动作CakePHP2测试登录()

<?php 
class UsersController extends AppController { 
    public $helpers = array('Html', 'Form'); 
    public $components = array('RequestHandler'); 

    public function beforeFilter() { 
     parent::beforeFilter(); 
     $this->Auth->allow('logout', 'login'); 
     // $this->Auth->allow('logout'); 
     $this->Security->csrfExpires = '+1 hour'; 
    } 

    public function login() { 
     if($this->request->is('post')) { 
      if ($this->Auth->login()) { 
       return $this->redirect($this->Auth->redirect()); 
      } else { 
       $this->Session->setFlash(__('Invalid username or password, try again'),'info'); 
      } 
     } 
    } 

的AppController.php

<?php 
App::uses('Controller', 'Controller'); 

class AppController extends Controller { 

    public $components = array(
     'Session', 
     'Security', 
     'Auth' => array(
      'loginRedirect' => array('controller' => 'dashboards', 'action' => 'index'), 
      'logoutRedirect' => array('controller' => 'dashboards', 'action' => 'welcome'), 
      'authorize' => array('Controller') 
     ) 
    ); 

    public function isAuthorized($user) { 
     //Admin can access every action 
     if (isset($user['role']) && $user['role'] === 'admin') { 
      return true; 
     } 

     //Default deny 
     $this->Session->setFlash('You are not allowed to access the requested page'); 
     return false; 
    } 

} 

的UsersControllerTest.php

<?php 

class UsersControllerTest extends ControllerTestCase { 
    public $autoRender = false; 
    public $fixtures = array('app.user','app.account'); 

    public function setUp() { 
     parent::setUp(); 
     $this->User = ClassRegistry::init('User'); 
    } 

...snip... 
    public function testLogin() { 

     $this->Users = $this->generate('Users', array(
      'components' => array(
       //'Session', 
       'Security' => array('_validatePost'), 
      ) 
     )); 
     $this->Users->Security->expects($this->any()) 
      ->method('_validatePost') 
      ->will($this->returnValue(true)); 

     $user = array(); 
     $user['User']['username'] = 'admin'; 
     //$user['User']['password'] = Security::hash('test', null, true); 
     $user['User']['password'] = 'test'; 

     $result = $this->testAction('/users/login', 
      array('data' => $user, 'method' => 'post', 'return' => 'contents') 
     ); 

     debug($this->contents); 
     //OUTPUTS: I get "Invalid username or password, try again" 
     //EXPECTED: A successful login message since I provided the correct credentials 

    } 

那么,如何在 $this->testAction('/users/login', array('data' => $user, 'method' => 'post', 'return' => 'contents'));什么都不返回时测试我的login()方法?

输出:我得到“无效的用户名或密码,请重试”

预期:成功的登录信息,因为我提供正确的凭据

任何答复将不胜感激。谢谢!

回答

4

感谢@jeremyharris我能够测试我的登录()

UsersControllerTest.php

public function testLogin() { 
    $this->Users = $this->generate('Users', array(
     'components' => array(
      'Security' => array('_validatePost'), 
     ) 
    )); 

    $data = array(); 
    $data['User']['username'] = 'admin'; 
    $data['User']['password'] = 'test'; 

    $this->Users->Auth->logout(); 
    $this->testAction('/users/login', 
     array('data' => $data, 'method' => 'post', 'return' => 'contents') 
    ); 

    $result = $this->testAction('/', 
     array('method' => 'get', 'return' => 'contents') 
    ); 

    // debug($result); 
    $this->assertContains('You are logged in as: <span class="label">admin</span>',$result); 
} 

public function testLoginInvalid() { 
    $this->Users = $this->generate('Users', array(
     'components' => array(
      'Security' => array('_validatePost'), 
     ) 
    )); 

    $data = array(); 
    $data['User']['username'] = 'admin'; 
    $data['User']['password'] = 'BLAH!'; 

    $this->Users->Auth->logout(); 
    $this->testAction('/users/login', 
     array('data' => $data, 'method' => 'post', 'return' => 'contents') 
    ); 

    $result = $this->testAction('/users/login', 
     array('method' => 'get', 'return' => 'contents') 
    ); 

    // debug($result); 
    $this->assertNotContains('You are logged in as',$result); 
    $this->assertContains('id="UserLoginForm" method="post"',$result); 
} 

UserFixture.php,我用了init()方法 - 作为@jeremyharris说关于哈希密码。

<?php 
App::uses('AuthComponent', 'Controller/Component'); 

class UserFixture extends CakeTestFixture { 
    /* Optional. Set this property to load fixtures to a different test datasource */ 
    public $useDbConfig = 'test'; 

    public $fields = array(
     'id' => array('type' => 'integer', 'key' => 'primary'), 
     'account_id' => array('type' => 'integer'), 
     'username' => array('type' => 'string', 'length' => 255, 'null' => false), 
     'email' => array('type' => 'string', 'length' => 255, 'null' => false), 
     'password' => array('type' => 'string', 'length' => 255, 'null' => false), 
     'password_token' => array('type' => 'string', 'length' => 255, 'null' => false), 
     'password_token_expiry' => array('type' => 'string', 'length' => 255, 'null' => false), 
     'role' => array('type' => 'string', 'length' => 25, 'null' => false), 
     'created' => 'datetime', 
     'modified' => 'datetime' 
    ); 

/* public $records = array(
     array('id'=>1, 'account_id' => 1, 'username' => 'admin', 'email' => '[email protected]', 'password' => 'f57f702f8d557ae5318fa49455cbe9838c1d1712', 'role' => 'admin', 'password_token'=>'', 'password_token_expiry'=>'','created' => '2012-03-18 10:39:23', 'modified' => '2012-03-18 10:41:31'), 
     array('id'=>2, 'account_id' => 1, 'username' => 'user', 'email' => '[email protected]', 'password' => 'f57f702f8d557ae5318fa49455cbe9838c1d1712', 'role' => 'user', 'password_token'=>'', 'password_token_expiry'=>'', 'created' => '2012-03-18 10:39:23', 'modified' => '2012-03-18 10:41:31') 
    ); 
*/ 
    public function init() { 
     $this->records = array(
      array('id'=>1, 'account_id' => 1, 'username' => 'admin', 'email' => '[email protected]', 'password' => AuthComponent::password('test'), 'role' => 'admin', 'password_token'=>'', 'password_token_expiry'=>'','created' => '2012-03-18 10:39:23', 'modified' => '2012-03-18 10:41:31'), 
      array('id'=>2, 'account_id' => 1, 'username' => 'user', 'email' => '[email protected]', 'password' => AuthComponent::password('test'), 'role' => 'user', 'password_token'=>'', 'password_token_expiry'=>'','created' => '2012-03-18 10:39:23', 'modified' => '2012-03-18 10:41:31'), 
     ); 
     parent::init(); 
    } 
} 

第一testAction()是一个POST,那么第二个获得“下一个”页面 - 从那里我做的断言。

0

问题是你在嘲笑整个Session组件。这意味着所有会话方法都将返回null。从$this->generate()删除'会话'键,你应该很好。

+0

感谢您的回复jeremyharris。但我仍然得到错误的结果。请参阅http://pastie.org/4110786 – wenbert

+1

在将密码传递给登录操作之前,您不应该对密码进行哈希处理。稍后由认证过程完成。另外,你没有设置任何东西,所以'$ this-> vars'将一直是空的。当它通过时,头部不会。如果您调试会话,您应该看到“Invalid username ...”消息。 – jeremyharris

+0

谢谢@jeremyharris。这就说得通了。但是,我遇到了一个新问题,现在我得到“无效的用户名/密码”而不是“传递”登录名。请参阅上面的更新代码。 – wenbert