mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-18 02:26:17 +00:00
Renaming configs to config and fixing Acl test.
Bringing Configure test coverage up to 82%, the best that can be achieved without calling __loadBootstrap(true) which will cause constant collision. git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@6932 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
parent
b7fbf8f080
commit
35391deff5
4 changed files with 145 additions and 33 deletions
|
@ -121,7 +121,7 @@ class Configure extends Object {
|
||||||
function &getInstance($boot = true) {
|
function &getInstance($boot = true) {
|
||||||
static $instance = array();
|
static $instance = array();
|
||||||
if (!$instance) {
|
if (!$instance) {
|
||||||
$instance[0] =& new Configure;
|
$instance[0] =& new Configure();
|
||||||
$instance[0]->__loadBootstrap($boot);
|
$instance[0]->__loadBootstrap($boot);
|
||||||
}
|
}
|
||||||
return $instance[0];
|
return $instance[0];
|
||||||
|
|
|
@ -26,7 +26,19 @@
|
||||||
* @lastmodified $Date$
|
* @lastmodified $Date$
|
||||||
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
|
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
|
||||||
*/
|
*/
|
||||||
uses('configure');
|
|
||||||
|
App::import('Core', 'Configure');
|
||||||
|
|
||||||
|
class TestConfigure extends Configure {
|
||||||
|
function &getInstance($boot = true) {
|
||||||
|
static $instance = array();
|
||||||
|
if (!$instance) {
|
||||||
|
$instance[0] =& Configure::getInstance();
|
||||||
|
$instance[0]->__loadBootstrap(false);
|
||||||
|
}
|
||||||
|
return $instance[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Short description for class.
|
* Short description for class.
|
||||||
|
@ -35,13 +47,30 @@ uses('configure');
|
||||||
* @subpackage cake.tests.cases.libs
|
* @subpackage cake.tests.cases.libs
|
||||||
*/
|
*/
|
||||||
class ConfigureTest extends UnitTestCase {
|
class ConfigureTest extends UnitTestCase {
|
||||||
|
|
||||||
function setUp() {
|
function setUp() {
|
||||||
$this->Configure =& Configure::getInstance();
|
parent::setUp();
|
||||||
|
$this->Configure =& TestConfigure::getInstance();
|
||||||
$this->Configure->write('Cache.disable', true);
|
$this->Configure->write('Cache.disable', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
function testListCoreObjects() {
|
function tearDown() {
|
||||||
|
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_core_paths')) {
|
||||||
|
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_core_paths');
|
||||||
|
}
|
||||||
|
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_dir_map')) {
|
||||||
|
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_dir_map');
|
||||||
|
}
|
||||||
|
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_file_map')) {
|
||||||
|
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_file_map');
|
||||||
|
}
|
||||||
|
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_object_map')) {
|
||||||
|
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_object_map');
|
||||||
|
}
|
||||||
|
parent::tearDown();
|
||||||
|
unset($this->Configure);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testListObjects() {
|
||||||
$result = $this->Configure->listObjects('class', TEST_CAKE_CORE_INCLUDE_PATH . 'libs');
|
$result = $this->Configure->listObjects('class', TEST_CAKE_CORE_INCLUDE_PATH . 'libs');
|
||||||
$this->assertTrue(in_array('Xml', $result));
|
$this->assertTrue(in_array('Xml', $result));
|
||||||
$this->assertTrue(in_array('Cache', $result));
|
$this->assertTrue(in_array('Cache', $result));
|
||||||
|
@ -61,11 +90,27 @@ class ConfigureTest extends UnitTestCase {
|
||||||
|
|
||||||
$result = $this->Configure->listObjects('helper');
|
$result = $this->Configure->listObjects('helper');
|
||||||
$this->assertTrue(in_array('Html', $result));
|
$this->assertTrue(in_array('Html', $result));
|
||||||
|
|
||||||
|
$result = $this->Configure->listObjects('model');
|
||||||
|
$notExpected = array('AppModel', 'Behavior', 'ConnectionManager', 'DbAcl', 'Model', 'Schema');
|
||||||
|
|
||||||
|
foreach ($notExpected as $class) {
|
||||||
|
$this->assertFalse(in_array($class, $result));
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = $this->Configure->listObjects('file');
|
||||||
|
$this->assertFalse($result);
|
||||||
|
|
||||||
|
$result = $this->Configure->listObjects('file', 'non_existing_configure');
|
||||||
|
$expected = array();
|
||||||
|
$this->assertEqual($result, $expected);
|
||||||
|
|
||||||
|
$result = $this->Configure->listObjects('NonExistingType');
|
||||||
|
$this->assertFalse($result);
|
||||||
}
|
}
|
||||||
|
|
||||||
function testRead() {
|
function testRead() {
|
||||||
$expected = 'ok';
|
$expected = 'ok';
|
||||||
|
|
||||||
$this->Configure->write('level1.level2.level3_1', $expected);
|
$this->Configure->write('level1.level2.level3_1', $expected);
|
||||||
$this->Configure->write('level1.level2.level3_2', 'something_else');
|
$this->Configure->write('level1.level2.level3_2', 'something_else');
|
||||||
$result = $this->Configure->read('level1.level2.level3_1');
|
$result = $this->Configure->read('level1.level2.level3_1');
|
||||||
|
@ -73,18 +118,16 @@ class ConfigureTest extends UnitTestCase {
|
||||||
|
|
||||||
$result = $this->Configure->read('level1.level2.level3_2');
|
$result = $this->Configure->read('level1.level2.level3_2');
|
||||||
$this->assertEqual($result, 'something_else');
|
$this->assertEqual($result, 'something_else');
|
||||||
|
|
||||||
|
$result = $this->Configure->read('debug');
|
||||||
|
$this->assertTrue($result >= 0);
|
||||||
|
|
||||||
|
unset($this->Configure->debug);
|
||||||
|
$result = $this->Configure->read('debug');
|
||||||
|
$this->assertTrue($result >= 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
function testThatWereOnlyListingUserlandClasses() {
|
function testWrite() {
|
||||||
$result = $this->Configure->listObjects('model');
|
|
||||||
$notExpected = array('AppModel', 'Behavior', 'ConnectionManager', 'DbAcl', 'Model', 'Schema');
|
|
||||||
|
|
||||||
foreach ($notExpected as $class) {
|
|
||||||
$this->assertFalse(in_array($class, $result));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function testWriteConfig() {
|
|
||||||
$this->Configure->write('SomeName.someKey', 'myvalue');
|
$this->Configure->write('SomeName.someKey', 'myvalue');
|
||||||
$result = $this->Configure->read('SomeName.someKey');
|
$result = $this->Configure->read('SomeName.someKey');
|
||||||
$this->assertEqual($result, 'myvalue');
|
$this->assertEqual($result, 'myvalue');
|
||||||
|
@ -94,25 +137,64 @@ class ConfigureTest extends UnitTestCase {
|
||||||
$this->assertEqual($result, null);
|
$this->assertEqual($result, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
function tearDown() {
|
function testDelete() {
|
||||||
unset($this->Configure);
|
$this->Configure->write('SomeName.someKey', 'myvalue');
|
||||||
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_core_paths')) {
|
$result = $this->Configure->read('SomeName.someKey');
|
||||||
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_core_paths');
|
$this->assertEqual($result, 'myvalue');
|
||||||
}
|
|
||||||
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_dir_map')) {
|
$this->Configure->delete('SomeName.someKey');
|
||||||
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_dir_map');
|
$result = $this->Configure->read('SomeName.someKey');
|
||||||
}
|
$this->assertTrue($result === null);
|
||||||
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_file_map')) {
|
|
||||||
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_file_map');
|
$this->Configure->write('SomeName', array('someKey' => 'myvalue', 'otherKey' => 'otherValue'));
|
||||||
}
|
|
||||||
if (file_exists(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_object_map')) {
|
$result = $this->Configure->read('SomeName.someKey');
|
||||||
unlink(TMP . 'cache' . DS . 'persistent' . DS . 'cake_core_object_map');
|
$this->assertEqual($result, 'myvalue');
|
||||||
}
|
|
||||||
|
$result = $this->Configure->read('SomeName.otherKey');
|
||||||
|
$this->assertEqual($result, 'otherValue');
|
||||||
|
|
||||||
|
$this->Configure->delete('SomeName');
|
||||||
|
|
||||||
|
$result = $this->Configure->read('SomeName.someKey');
|
||||||
|
$this->assertTrue($result === null);
|
||||||
|
|
||||||
|
$result = $this->Configure->read('SomeName.otherKey');
|
||||||
|
$this->assertTrue($result === null);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testLoad() {
|
||||||
|
$result = $this->Configure->load('non_existing_configuration_file');
|
||||||
|
$this->assertFalse($result);
|
||||||
|
|
||||||
|
$result = $this->Configure->load('config');
|
||||||
|
$this->assertTrue($result === null);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testStore() {
|
||||||
|
$this->Configure->store(null, 'test', array('data' => 'value'));
|
||||||
|
|
||||||
|
$this->Configure->store(null, 'test', array('data' => array('first' => 'value', 'second' => 'value2')));
|
||||||
|
}
|
||||||
|
|
||||||
|
function testVersion() {
|
||||||
|
$result = $this->Configure->version();
|
||||||
|
$this->assertTrue(version_compare($result, '1.2', '>='));
|
||||||
|
|
||||||
|
unset($this->Configure->Cake['version']);
|
||||||
|
$result = $this->Configure->version();
|
||||||
|
$this->assertTrue(version_compare($result, '1.2', '>='));
|
||||||
|
}
|
||||||
|
|
||||||
|
function testBuildPaths() {
|
||||||
|
$this->Configure->buildPaths(array());
|
||||||
|
$this->assertTrue(!empty($this->Configure->modelPaths));
|
||||||
|
|
||||||
|
$this->Configure->buildPaths(array('model' => 'dummy'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class AppImportTest extends UnitTestCase {
|
class AppImportTest extends UnitTestCase {
|
||||||
|
|
||||||
function testClassLoading() {
|
function testClassLoading() {
|
||||||
$file = App::import();
|
$file = App::import();
|
||||||
$this->assertTrue($file);
|
$this->assertTrue($file);
|
||||||
|
@ -126,6 +208,24 @@ class AppImportTest extends UnitTestCase {
|
||||||
$file = App::import('Model', 'AppModel', false);
|
$file = App::import('Model', 'AppModel', false);
|
||||||
$this->assertTrue($file);
|
$this->assertTrue($file);
|
||||||
|
|
||||||
|
$file = App::import('WrongType', null, true, array(), '');
|
||||||
|
$this->assertTrue($file);
|
||||||
|
|
||||||
|
$file = App::import('Model', 'NonExistingPlugin.NonExistingModel', false);
|
||||||
|
$this->assertFalse($file);
|
||||||
|
|
||||||
|
$file = App::import('Core', 'NonExistingPlugin.NonExistingModel', false);
|
||||||
|
$this->assertFalse($file);
|
||||||
|
|
||||||
|
$file = App::import('Model', array('NonExistingPlugin.NonExistingModel'), false);
|
||||||
|
$this->assertFalse($file);
|
||||||
|
|
||||||
|
$file = App::import('Core', array('NonExistingPlugin.NonExistingModel'), false);
|
||||||
|
$this->assertFalse($file);
|
||||||
|
|
||||||
|
$file = App::import('Core', array('NonExistingPlugin.NonExistingModel.AnotherChild'), false);
|
||||||
|
$this->assertFalse($file);
|
||||||
|
|
||||||
if (!class_exists('AppController')) {
|
if (!class_exists('AppController')) {
|
||||||
$classes = array_flip(get_declared_classes());
|
$classes = array_flip(get_declared_classes());
|
||||||
|
|
||||||
|
@ -149,6 +249,18 @@ class AppImportTest extends UnitTestCase {
|
||||||
$this->assertTrue(isset($classes['pagescontroller']));
|
$this->assertTrue(isset($classes['pagescontroller']));
|
||||||
$this->assertTrue(isset($classes['appcontroller']));
|
$this->assertTrue(isset($classes['appcontroller']));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$file = App::import('Behavior', 'Containable');
|
||||||
|
$this->assertTrue($file);
|
||||||
|
|
||||||
|
$file = App::import('Component', 'RequestHandler');
|
||||||
|
$this->assertTrue($file);
|
||||||
|
|
||||||
|
$file = App::import('Helper', 'Form');
|
||||||
|
$this->assertTrue($file);
|
||||||
|
|
||||||
|
$file = App::import('Model', 'NonExistingModel');
|
||||||
|
$this->assertFalse($file);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -291,7 +291,7 @@ class AclComponentTest extends CakeTestCase {
|
||||||
Configure::write('Acl.classname', 'INI_ACL_TEST');
|
Configure::write('Acl.classname', 'INI_ACL_TEST');
|
||||||
unset($this->Acl);
|
unset($this->Acl);
|
||||||
$this->Acl = new AclComponent();
|
$this->Acl = new AclComponent();
|
||||||
$iniFile = TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'configs'. DS . 'acl.ini.php';
|
$iniFile = TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'config'. DS . 'acl.ini.php';
|
||||||
$result = $this->Acl->_Instance->readConfigFile($iniFile);
|
$result = $this->Acl->_Instance->readConfigFile($iniFile);
|
||||||
$expected = array(
|
$expected = array(
|
||||||
'admin' => array(
|
'admin' => array(
|
||||||
|
@ -333,7 +333,7 @@ class AclComponentTest extends CakeTestCase {
|
||||||
function testIniCheck() {
|
function testIniCheck() {
|
||||||
Configure::write('Acl.classname', 'INI_ACL_TEST');
|
Configure::write('Acl.classname', 'INI_ACL_TEST');
|
||||||
unset($this->Acl);
|
unset($this->Acl);
|
||||||
$iniFile = TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'configs'. DS . 'acl.ini.php';
|
$iniFile = TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'config'. DS . 'acl.ini.php';
|
||||||
|
|
||||||
$this->Acl = new AclComponent();
|
$this->Acl = new AclComponent();
|
||||||
$this->Acl->_Instance->config= $this->Acl->_Instance->readConfigFile($iniFile);
|
$this->Acl->_Instance->config= $this->Acl->_Instance->readConfigFile($iniFile);
|
||||||
|
|
Loading…
Add table
Reference in a new issue