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:
mariano.iglesias 2008-05-18 22:51:29 +00:00
parent b7fbf8f080
commit 35391deff5
4 changed files with 145 additions and 33 deletions

View file

@ -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];

View file

@ -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);
} }
} }

View 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);