2011-01-02 18:35:43 +00:00
|
|
|
<?php
|
2011-01-03 18:00:06 +00:00
|
|
|
/**
|
2011-10-10 21:18:48 +00:00
|
|
|
* ControllerAuthorizeTest file
|
2011-01-03 18:00:06 +00:00
|
|
|
*
|
2017-06-10 21:33:55 +00:00
|
|
|
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
|
2017-06-10 22:10:52 +00:00
|
|
|
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
|
2011-01-03 18:00:06 +00:00
|
|
|
*
|
|
|
|
* Licensed under The MIT License
|
2013-02-08 12:22:51 +00:00
|
|
|
* For full copyright and license information, please see the LICENSE.txt
|
2011-01-03 18:00:06 +00:00
|
|
|
* Redistributions of files must retain the above copyright notice.
|
|
|
|
*
|
2017-06-10 22:10:52 +00:00
|
|
|
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
|
2017-06-10 21:33:55 +00:00
|
|
|
* @link https://cakephp.org CakePHP(tm) Project
|
2011-07-26 06:16:14 +00:00
|
|
|
* @package Cake.Test.Case.Controller.Component.Auth
|
2011-01-03 18:00:06 +00:00
|
|
|
* @since CakePHP(tm) v 2.0
|
2017-06-10 22:23:14 +00:00
|
|
|
* @license https://opensource.org/licenses/mit-license.php MIT License
|
2011-01-03 18:00:06 +00:00
|
|
|
*/
|
2011-03-06 00:03:36 +00:00
|
|
|
|
|
|
|
App::uses('Controller', 'Controller');
|
|
|
|
App::uses('ControllerAuthorize', 'Controller/Component/Auth');
|
|
|
|
App::uses('CakeRequest', 'Network');
|
|
|
|
App::uses('CakeResponse', 'Network');
|
2011-01-02 18:35:43 +00:00
|
|
|
|
2013-05-30 22:11:14 +00:00
|
|
|
/**
|
2016-08-10 10:22:09 +00:00
|
|
|
* ControllerAuthorizeTest
|
2013-05-30 22:11:14 +00:00
|
|
|
*
|
|
|
|
* @package Cake.Test.Case.Controller.Component.Auth
|
|
|
|
*/
|
2011-01-02 18:35:43 +00:00
|
|
|
class ControllerAuthorizeTest extends CakeTestCase {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* setup
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2022-12-28 07:03:39 +00:00
|
|
|
public function setUp() : void {
|
2011-01-02 18:35:43 +00:00
|
|
|
parent::setUp();
|
|
|
|
$this->controller = $this->getMock('Controller', array('isAuthorized'), array(), '', false);
|
2011-02-18 04:17:07 +00:00
|
|
|
$this->components = $this->getMock('ComponentCollection');
|
|
|
|
$this->components->expects($this->any())
|
|
|
|
->method('getController')
|
|
|
|
->will($this->returnValue($this->controller));
|
2011-10-28 05:01:17 +00:00
|
|
|
|
2011-02-18 04:17:07 +00:00
|
|
|
$this->auth = new ControllerAuthorize($this->components);
|
2011-01-02 18:35:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-09-25 15:22:00 +00:00
|
|
|
* testControllerTypeError
|
|
|
|
*
|
2014-04-02 01:02:37 +00:00
|
|
|
* @return void
|
2022-12-31 00:48:04 +00:00
|
|
|
* @throws \PHPUnit\Framework\Error
|
2011-01-02 18:35:43 +00:00
|
|
|
*/
|
2011-05-30 20:02:32 +00:00
|
|
|
public function testControllerTypeError() {
|
2022-12-31 00:48:04 +00:00
|
|
|
$this->expectException(\PHPUnit\Framework\Error::class);
|
2015-12-13 20:12:31 +00:00
|
|
|
try {
|
|
|
|
$this->auth->controller(new StdClass());
|
2016-12-05 21:14:33 +00:00
|
|
|
$this->fail('No exception thrown');
|
2016-12-07 02:20:32 +00:00
|
|
|
} catch (TypeError $e) {
|
2022-12-31 00:48:04 +00:00
|
|
|
throw new \PHPUnit\Framework\Error('Raised an error', 100);
|
2015-12-13 20:12:31 +00:00
|
|
|
}
|
2011-01-02 18:35:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-09-25 15:22:00 +00:00
|
|
|
* testControllerErrorOnMissingMethod
|
|
|
|
*
|
2014-04-02 01:02:37 +00:00
|
|
|
* @return void
|
2011-01-02 18:35:43 +00:00
|
|
|
*/
|
2011-05-30 20:02:32 +00:00
|
|
|
public function testControllerErrorOnMissingMethod() {
|
2022-12-31 04:13:42 +00:00
|
|
|
$this->expectException(CakeException::class);
|
2011-01-02 18:35:43 +00:00
|
|
|
$this->auth->controller(new Controller());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* test failure
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2011-05-30 20:02:32 +00:00
|
|
|
public function testAuthorizeFailure() {
|
2011-01-02 18:35:43 +00:00
|
|
|
$user = array();
|
|
|
|
$request = new CakeRequest('/posts/index', false);
|
|
|
|
$this->assertFalse($this->auth->authorize($user, $request));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* test isAuthorized working.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2011-05-30 20:02:32 +00:00
|
|
|
public function testAuthorizeSuccess() {
|
2011-01-02 18:35:43 +00:00
|
|
|
$user = array('User' => array('username' => 'mark'));
|
|
|
|
$request = new CakeRequest('/posts/index', false);
|
2011-10-28 05:01:17 +00:00
|
|
|
|
2011-01-02 18:35:43 +00:00
|
|
|
$this->controller->expects($this->once())
|
|
|
|
->method('isAuthorized')
|
|
|
|
->with($user)
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$this->assertTrue($this->auth->authorize($user, $request));
|
|
|
|
}
|
2014-04-02 01:02:37 +00:00
|
|
|
|
2011-01-02 18:35:43 +00:00
|
|
|
}
|