93 lines
2.4 KiB
PHP
93 lines
2.4 KiB
PHP
<?php
|
|
/**
|
|
* AclComponentTest file
|
|
*
|
|
* PHP 5
|
|
*
|
|
* CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
|
|
* Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
*
|
|
* Licensed under The MIT License
|
|
* For full copyright and license information, please see the LICENSE.txt
|
|
* Redistributions of files must retain the above copyright notice
|
|
*
|
|
* @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
* @link http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
|
* @package Cake.Test.Case.Controller.Component
|
|
* @since CakePHP(tm) v 1.2.0.5435
|
|
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
|
|
*/
|
|
App::uses('AclComponent', 'Controller/Component');
|
|
class_exists('AclComponent');
|
|
|
|
/**
|
|
* Test Case for AclComponent
|
|
*
|
|
* @package Cake.Test.Case.Controller.Component
|
|
*/
|
|
class AclComponentTest extends CakeTestCase {
|
|
|
|
/**
|
|
* setUp method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function setUp() {
|
|
parent::setUp();
|
|
if (!class_exists('MockAclImplementation', false)) {
|
|
$this->getMock('AclInterface', array(), array(), 'MockAclImplementation');
|
|
}
|
|
Configure::write('Acl.classname', 'MockAclImplementation');
|
|
$Collection = new ComponentCollection();
|
|
$this->Acl = new AclComponent($Collection);
|
|
}
|
|
|
|
/**
|
|
* tearDown method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function tearDown() {
|
|
parent::tearDown();
|
|
unset($this->Acl);
|
|
}
|
|
|
|
/**
|
|
* test that constructor throws an exception when Acl.classname is a
|
|
* non-existent class
|
|
*
|
|
* @expectedException CakeException
|
|
* @return void
|
|
*/
|
|
public function testConstrutorException() {
|
|
Configure::write('Acl.classname', 'AclClassNameThatDoesNotExist');
|
|
$Collection = new ComponentCollection();
|
|
new AclComponent($Collection);
|
|
}
|
|
|
|
/**
|
|
* test that adapter() allows control of the internal implementation AclComponent uses.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testAdapter() {
|
|
$implementation = new MockAclImplementation();
|
|
$implementation->expects($this->once())->method('initialize')->with($this->Acl);
|
|
$this->assertNull($this->Acl->adapter($implementation));
|
|
|
|
$this->assertEquals($this->Acl->adapter(), $implementation, 'Returned object is different %s');
|
|
}
|
|
|
|
/**
|
|
* test that adapter() whines when the class is not an AclBase
|
|
*
|
|
* @expectedException CakeException
|
|
* @return void
|
|
*/
|
|
public function testAdapterException() {
|
|
$thing = new StdClass();
|
|
$this->Acl->adapter($thing);
|
|
}
|
|
|
|
}
|