2009-09-24 16:23:24 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Connection Manager tests
|
|
|
|
*
|
|
|
|
*
|
2010-10-03 12:31:21 -04:00
|
|
|
* PHP 5
|
2009-09-24 16:23:24 -04:00
|
|
|
*
|
2010-01-26 14:18:20 -05:00
|
|
|
* Copyright 2005-2010, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2009-09-24 16:23:24 -04:00
|
|
|
*
|
2010-10-03 12:31:21 -04:00
|
|
|
* Licensed under The MIT License
|
|
|
|
* Redistributions of files must retain the above copyright notice
|
2009-09-24 16:23:24 -04:00
|
|
|
*
|
2010-01-26 14:18:20 -05:00
|
|
|
* @copyright Copyright 2005-2010, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2010-05-18 22:15:13 -03:00
|
|
|
* @link http://book.cakephp.org/view/1196/Testing CakePHP(tm) Tests
|
2010-12-24 13:57:20 -05:00
|
|
|
* @package cake.tests.cases.libs
|
2009-09-24 16:23:24 -04:00
|
|
|
* @since CakePHP(tm) v 1.2.0.5550
|
2010-10-03 12:27:27 -04:00
|
|
|
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
|
2009-09-24 16:23:24 -04:00
|
|
|
*/
|
2010-12-09 01:25:24 -04:30
|
|
|
App::uses('ConnectionManager', 'Model');
|
2009-09-24 16:23:24 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ConnectionManagerTest
|
|
|
|
*
|
2010-12-24 13:57:20 -05:00
|
|
|
* @package cake.tests.cases.models
|
2009-09-24 16:23:24 -04:00
|
|
|
*/
|
|
|
|
class ConnectionManagerTest extends CakeTestCase {
|
|
|
|
|
2011-05-10 00:10:15 -04:30
|
|
|
|
|
|
|
/**
|
|
|
|
* tearDown method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function tearDown() {
|
|
|
|
CakePlugin::unload();
|
|
|
|
}
|
2009-09-24 16:23:24 -04:00
|
|
|
/**
|
|
|
|
* testEnumConnectionObjects method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testEnumConnectionObjects() {
|
|
|
|
$sources = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertTrue(count($sources) >= 1);
|
|
|
|
|
2010-09-19 22:28:30 -04:30
|
|
|
$connections = array('default', 'test', 'test');
|
2009-09-24 16:23:24 -04:00
|
|
|
$this->assertTrue(count(array_intersect(array_keys($sources), $connections)) >= 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testGetDataSource method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testGetDataSource() {
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
2010-06-04 23:47:38 -04:30
|
|
|
$this->assertTrue((bool)(count(array_keys($connections) >= 1)));
|
2009-09-24 16:23:24 -04:00
|
|
|
|
|
|
|
$source = ConnectionManager::getDataSource(key($connections));
|
|
|
|
$this->assertTrue(is_object($source));
|
2011-01-12 23:08:34 -02:00
|
|
|
}
|
2009-09-24 16:23:24 -04:00
|
|
|
|
2011-01-12 23:08:34 -02:00
|
|
|
/**
|
|
|
|
* testGetDataSourceException() method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @expectedException MissingDatasourceConfigException
|
|
|
|
*/
|
|
|
|
public function testGetDataSourceException() {
|
|
|
|
ConnectionManager::getDataSource('non_existent_source');
|
2009-09-24 16:23:24 -04:00
|
|
|
}
|
|
|
|
|
2009-09-24 22:56:02 -04:00
|
|
|
/**
|
|
|
|
* testGetPluginDataSource method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testGetPluginDataSource() {
|
|
|
|
App::build(array(
|
2011-04-17 12:35:21 +02:00
|
|
|
'plugins' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS)
|
2009-09-24 22:56:02 -04:00
|
|
|
));
|
2011-05-10 00:10:15 -04:30
|
|
|
CakePlugin::load('TestPlugin');
|
2009-09-24 22:56:02 -04:00
|
|
|
$name = 'test_source';
|
|
|
|
$config = array('datasource' => 'TestPlugin.TestSource');
|
|
|
|
$connection = ConnectionManager::create($name, $config);
|
|
|
|
|
|
|
|
$this->assertTrue(class_exists('TestSource'));
|
|
|
|
$this->assertEqual($connection->configKeyName, $name);
|
|
|
|
$this->assertEqual($connection->config, $config);
|
|
|
|
|
|
|
|
App::build();
|
|
|
|
}
|
|
|
|
|
2010-02-16 22:35:16 -05:00
|
|
|
/**
|
|
|
|
* testGetPluginDataSourceAndPluginDriver method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testGetPluginDataSourceAndPluginDriver() {
|
|
|
|
App::build(array(
|
2011-04-17 12:35:21 +02:00
|
|
|
'plugins' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS)
|
2010-02-16 22:35:16 -05:00
|
|
|
));
|
2011-05-10 00:10:15 -04:30
|
|
|
CakePlugin::load('TestPlugin');
|
2010-02-16 22:35:16 -05:00
|
|
|
$name = 'test_plugin_source_and_driver';
|
2011-01-05 22:15:17 -04:30
|
|
|
$config = array('datasource' => 'TestPlugin.Database/TestDriver');
|
2010-02-16 22:35:16 -05:00
|
|
|
|
|
|
|
$connection = ConnectionManager::create($name, $config);
|
|
|
|
|
|
|
|
$this->assertTrue(class_exists('TestSource'));
|
|
|
|
$this->assertTrue(class_exists('TestDriver'));
|
|
|
|
$this->assertEqual($connection->configKeyName, $name);
|
|
|
|
$this->assertEqual($connection->config, $config);
|
|
|
|
|
|
|
|
App::build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testGetLocalDataSourceAndPluginDriver method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testGetLocalDataSourceAndPluginDriver() {
|
|
|
|
App::build(array(
|
2011-04-17 12:35:21 +02:00
|
|
|
'plugins' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS)
|
2010-02-16 22:35:16 -05:00
|
|
|
));
|
2011-05-10 00:10:15 -04:30
|
|
|
CakePlugin::load('TestPlugin');
|
2010-02-16 22:35:16 -05:00
|
|
|
$name = 'test_local_source_and_plugin_driver';
|
2011-01-05 22:15:17 -04:30
|
|
|
$config = array('datasource' => 'TestPlugin.Database/DboDummy');
|
2010-02-16 22:35:16 -05:00
|
|
|
|
|
|
|
$connection = ConnectionManager::create($name, $config);
|
|
|
|
|
|
|
|
$this->assertTrue(class_exists('DboSource'));
|
|
|
|
$this->assertTrue(class_exists('DboDummy'));
|
|
|
|
$this->assertEqual($connection->configKeyName, $name);
|
|
|
|
|
|
|
|
App::build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testGetPluginDataSourceAndLocalDriver method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testGetPluginDataSourceAndLocalDriver() {
|
|
|
|
App::build(array(
|
2011-04-17 12:35:21 +02:00
|
|
|
'plugins' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS),
|
2011-03-22 00:46:51 -04:30
|
|
|
'Model/Datasource/Database' => array(
|
2011-04-17 12:35:21 +02:00
|
|
|
CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS . 'Datasource' . DS . 'Database' . DS
|
2011-03-22 00:46:51 -04:30
|
|
|
)
|
2010-02-16 22:35:16 -05:00
|
|
|
));
|
|
|
|
|
|
|
|
$name = 'test_plugin_source_and_local_driver';
|
2011-01-05 22:15:17 -04:30
|
|
|
$config = array('datasource' => 'Database/TestLocalDriver');
|
2010-02-16 22:35:16 -05:00
|
|
|
|
|
|
|
$connection = ConnectionManager::create($name, $config);
|
|
|
|
|
|
|
|
$this->assertTrue(class_exists('TestSource'));
|
|
|
|
$this->assertTrue(class_exists('TestLocalDriver'));
|
|
|
|
$this->assertEqual($connection->configKeyName, $name);
|
|
|
|
$this->assertEqual($connection->config, $config);
|
|
|
|
App::build();
|
|
|
|
}
|
|
|
|
|
2009-09-24 16:23:24 -04:00
|
|
|
/**
|
|
|
|
* testSourceList method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testSourceList() {
|
|
|
|
$sources = ConnectionManager::sourceList();
|
|
|
|
$this->assertTrue(count($sources) >= 1);
|
|
|
|
|
2010-09-19 22:28:30 -04:30
|
|
|
$connections = array('default', 'test', 'test');
|
2009-09-24 16:23:24 -04:00
|
|
|
$this->assertTrue(count(array_intersect($sources, $connections)) >= 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testGetSourceName method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testGetSourceName() {
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$name = key($connections);
|
|
|
|
$source = ConnectionManager::getDataSource($name);
|
|
|
|
$result = ConnectionManager::getSourceName($source);
|
|
|
|
|
|
|
|
$this->assertEqual($result, $name);
|
2009-09-24 23:48:52 -04:00
|
|
|
|
2010-06-04 23:47:38 -04:30
|
|
|
$source = new StdClass();
|
2009-09-24 23:48:52 -04:00
|
|
|
$result = ConnectionManager::getSourceName($source);
|
|
|
|
$this->assertEqual($result, null);
|
2009-09-24 16:23:24 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testLoadDataSource method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testLoadDataSource() {
|
|
|
|
$connections = array(
|
2011-01-06 00:09:11 -04:30
|
|
|
array('classname' => 'Mysql', 'filename' => 'Mysql', 'package' => 'Database'),
|
|
|
|
array('classname' => 'Postgres', 'filename' => 'Postgres', 'package' => 'Database'),
|
|
|
|
array('classname' => 'Sqlite', 'filename' => 'Sqlite', 'package' => 'Database'),
|
2009-09-24 16:23:24 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
foreach ($connections as $connection) {
|
|
|
|
$exists = class_exists($connection['classname']);
|
|
|
|
$loaded = ConnectionManager::loadDataSource($connection);
|
2011-01-06 00:09:11 -04:30
|
|
|
$this->assertEqual($loaded, !$exists, "Failed loading the {$connection['classname']} datasource");
|
2009-09-24 16:23:24 -04:00
|
|
|
}
|
2011-01-12 23:08:34 -02:00
|
|
|
}
|
2009-09-24 16:23:24 -04:00
|
|
|
|
2011-01-12 23:08:34 -02:00
|
|
|
/**
|
|
|
|
* testLoadDataSourceException() method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @expectedException MissingDatasourceFileException
|
|
|
|
*/
|
|
|
|
public function testLoadDataSourceException() {
|
2009-09-24 16:23:24 -04:00
|
|
|
$connection = array('classname' => 'NonExistentDataSource', 'filename' => 'non_existent');
|
|
|
|
$loaded = ConnectionManager::loadDataSource($connection);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testCreateDataSource method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testCreateDataSourceWithIntegrationTests() {
|
|
|
|
$name = 'test_created_connection';
|
|
|
|
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
2010-06-04 23:47:38 -04:30
|
|
|
$this->assertTrue((bool)(count(array_keys($connections) >= 1)));
|
2009-09-24 16:23:24 -04:00
|
|
|
|
|
|
|
$source = ConnectionManager::getDataSource(key($connections));
|
|
|
|
$this->assertTrue(is_object($source));
|
|
|
|
|
|
|
|
$config = $source->config;
|
|
|
|
$connection = ConnectionManager::create($name, $config);
|
|
|
|
|
|
|
|
$this->assertTrue(is_object($connection));
|
|
|
|
$this->assertEqual($name, $connection->configKeyName);
|
|
|
|
$this->assertEqual($name, ConnectionManager::getSourceName($connection));
|
|
|
|
|
|
|
|
$source = ConnectionManager::create(null, array());
|
|
|
|
$this->assertEqual($source, null);
|
|
|
|
|
|
|
|
$source = ConnectionManager::create('another_test', array());
|
|
|
|
$this->assertEqual($source, null);
|
|
|
|
|
|
|
|
$config = array('classname' => 'DboMysql', 'filename' => 'dbo' . DS . 'dbo_mysql');
|
|
|
|
$source = ConnectionManager::create(null, $config);
|
|
|
|
$this->assertEqual($source, null);
|
|
|
|
}
|
2010-06-20 23:53:54 -03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* testConnectionData method
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testConnectionData() {
|
|
|
|
App::build(array(
|
2011-04-17 12:35:21 +02:00
|
|
|
'plugins' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS),
|
2011-03-22 00:46:51 -04:30
|
|
|
'Model/Datasource' => array(
|
2011-04-17 12:35:21 +02:00
|
|
|
CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS . 'Datasource' . DS
|
2011-03-22 00:46:51 -04:30
|
|
|
)
|
2010-06-20 23:53:54 -03:00
|
|
|
));
|
2011-05-10 00:10:15 -04:30
|
|
|
CakePlugin::loadAll();
|
2010-06-20 23:53:54 -03:00
|
|
|
$expected = array(
|
2011-01-05 22:15:17 -04:30
|
|
|
'datasource' => 'Test2Source'
|
2010-06-20 23:53:54 -03:00
|
|
|
);
|
|
|
|
|
2011-01-05 22:15:17 -04:30
|
|
|
ConnectionManager::create('connection1', array('datasource' => 'Test2Source'));
|
2010-06-20 23:53:54 -03:00
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertEqual($expected, $connections['connection1']);
|
|
|
|
|
|
|
|
ConnectionManager::create('connection2', array('datasource' => 'Test2Source'));
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertEqual($expected, $connections['connection2']);
|
|
|
|
|
2011-01-05 22:15:17 -04:30
|
|
|
ConnectionManager::create('connection3', array('datasource' => 'TestPlugin.TestSource'));
|
2010-06-20 23:53:54 -03:00
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
2011-01-05 22:15:17 -04:30
|
|
|
$expected['datasource'] = 'TestPlugin.TestSource';
|
2010-06-20 23:53:54 -03:00
|
|
|
$this->assertEqual($expected, $connections['connection3']);
|
|
|
|
|
|
|
|
ConnectionManager::create('connection4', array('datasource' => 'TestPlugin.TestSource'));
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertEqual($expected, $connections['connection4']);
|
|
|
|
|
2011-01-05 22:15:17 -04:30
|
|
|
ConnectionManager::create('connection5', array('datasource' => 'Test2OtherSource'));
|
2010-06-20 23:53:54 -03:00
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
2011-01-05 22:15:17 -04:30
|
|
|
$expected['datasource'] = 'Test2OtherSource';
|
|
|
|
|
2010-06-20 23:53:54 -03:00
|
|
|
$this->assertEqual($expected, $connections['connection5']);
|
|
|
|
|
|
|
|
ConnectionManager::create('connection6', array('datasource' => 'Test2OtherSource'));
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertEqual($expected, $connections['connection6']);
|
|
|
|
|
2011-01-05 22:15:17 -04:30
|
|
|
ConnectionManager::create('connection7', array('datasource' => 'TestPlugin.TestOtherSource'));
|
2010-06-20 23:53:54 -03:00
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
2011-01-05 22:15:17 -04:30
|
|
|
$expected['datasource'] = 'TestPlugin.TestOtherSource';
|
|
|
|
|
2010-06-20 23:53:54 -03:00
|
|
|
$this->assertEqual($expected, $connections['connection7']);
|
|
|
|
|
|
|
|
ConnectionManager::create('connection8', array('datasource' => 'TestPlugin.TestOtherSource'));
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertEqual($expected, $connections['connection8']);
|
|
|
|
}
|
2011-04-16 22:57:05 -04:30
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests that a connection configuration can be deleted in runtime
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testDrop() {
|
|
|
|
App::build(array(
|
|
|
|
'Model/Datasource' => array(
|
2011-04-17 12:35:21 +02:00
|
|
|
CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS . 'Datasource' . DS
|
2011-04-16 22:57:05 -04:30
|
|
|
)
|
|
|
|
));
|
|
|
|
ConnectionManager::create('droppable', array('datasource' => 'Test2Source'));
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertEqual(array('datasource' => 'Test2Source'), $connections['droppable']);
|
|
|
|
|
|
|
|
$this->assertTrue(ConnectionManager::drop('droppable'));
|
|
|
|
$connections = ConnectionManager::enumConnectionObjects();
|
|
|
|
$this->assertFalse(isset($connections['droppable']));
|
|
|
|
}
|
2009-09-24 16:23:24 -04:00
|
|
|
}
|