Fixing Router and Dispatcher so they user the plugin loader

This commit is contained in:
Jose Lorenzo Rodriguez 2011-05-09 00:01:00 -04:30
parent 2c3132fa85
commit ca99b5b515
6 changed files with 25 additions and 17 deletions

View file

@ -579,7 +579,7 @@ class Router {
* @access private * @access private
*/ */
private static function __connectDefaultRoutes() { private static function __connectDefaultRoutes() {
if ($plugins = App::objects('plugin')) { if ($plugins = CakePlugin::loaded()) {
App::uses('PluginShortRoute', 'Routing/Route'); App::uses('PluginShortRoute', 'Routing/Route');
foreach ($plugins as $key => $value) { foreach ($plugins as $key => $value) {
$plugins[$key] = Inflector::underscore($value); $plugins[$key] = Inflector::underscore($value);

View file

@ -553,6 +553,7 @@ class DispatcherTest extends CakeTestCase {
$_FILES = $this->_files; $_FILES = $this->_files;
$_SERVER = $this->_server; $_SERVER = $this->_server;
App::build(); App::build();
CakePlugin::unload();
Configure::write('App', $this->_app); Configure::write('App', $this->_app);
Configure::write('Cache', $this->_cache); Configure::write('Cache', $this->_cache);
Configure::write('debug', $this->_debug); Configure::write('debug', $this->_debug);
@ -925,7 +926,7 @@ class DispatcherTest extends CakeTestCase {
$plugins[] = 'MyPlugin'; $plugins[] = 'MyPlugin';
$plugins[] = 'ArticlesTest'; $plugins[] = 'ArticlesTest';
App::setObjects('plugin', $plugins); CakePlugin::load('MyPlugin', array('path' => '/fake/path'));
Router::reload(); Router::reload();
$Dispatcher = new TestDispatcher(); $Dispatcher = new TestDispatcher();
@ -982,6 +983,7 @@ class DispatcherTest extends CakeTestCase {
$this->assertEqual($controller->passedArgs, $expected); $this->assertEqual($controller->passedArgs, $expected);
Configure::write('Routing.prefixes', array('admin')); Configure::write('Routing.prefixes', array('admin'));
CakePLugin::load('ArticlesTest', array('path' => '/fake/path'));
Router::reload(); Router::reload();
$Dispatcher = new TestDispatcher(); $Dispatcher = new TestDispatcher();
@ -1002,7 +1004,7 @@ class DispatcherTest extends CakeTestCase {
'return' => 1 'return' => 1
); );
foreach ($expected as $key => $value) { foreach ($expected as $key => $value) {
$this->assertEqual($controller->request[$key], $expected[$key], 'Value mismatch ' . $key . ' %s'); $this->assertEqual($controller->request[$key], $expected[$key], 'Value mismatch ' . $key);
} }
} }
@ -1013,12 +1015,7 @@ class DispatcherTest extends CakeTestCase {
* @return void * @return void
*/ */
public function testAutomaticPluginDispatchWithShortAccess() { public function testAutomaticPluginDispatchWithShortAccess() {
$_POST = array(); CakePlugin::load('MyPlugin', array('path' => '/fake/path'));
$_SERVER['PHP_SELF'] = '/cake/repo/branches/1.2.x.x/index.php';
$plugins = App::objects('plugin');
$plugins[] = 'MyPlugin';
App::setObjects('plugin', $plugins);
Router::reload(); Router::reload();
$Dispatcher = new TestDispatcher(); $Dispatcher = new TestDispatcher();
@ -1047,7 +1044,7 @@ class DispatcherTest extends CakeTestCase {
App::build(array( App::build(array(
'plugins' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS) 'plugins' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS)
), true); ), true);
App::objects('plugin', null, false); CakePlugin::loadAll();
$Dispatcher = new TestDispatcher(); $Dispatcher = new TestDispatcher();
$Dispatcher->base = false; $Dispatcher->base = false;
@ -1147,7 +1144,7 @@ class DispatcherTest extends CakeTestCase {
App::build(array( App::build(array(
'plugins' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS) 'plugins' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS)
)); ));
App::objects('plugin', null, false); CakePlugin::loadAll();
Router::reload(); Router::reload();
Router::parse('/'); Router::parse('/');
@ -1207,6 +1204,7 @@ class DispatcherTest extends CakeTestCase {
'vendors' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'vendors'. DS), 'vendors' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'vendors'. DS),
'View' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'View'. DS) 'View' => array(LIBS . 'tests' . DS . 'test_app' . DS . 'View'. DS)
)); ));
CakePlugin::loadAll();
$Dispatcher = new TestDispatcher(); $Dispatcher = new TestDispatcher();
$Dispatcher->response = $this->getMock('CakeResponse', array('_sendHeader')); $Dispatcher->response = $this->getMock('CakeResponse', array('_sendHeader'));
@ -1264,20 +1262,20 @@ class DispatcherTest extends CakeTestCase {
ob_start(); ob_start();
$Dispatcher->asset('test_plugin/root.js'); $Dispatcher->asset('test_plugin/root.js');
$result = ob_get_clean(); $result = ob_get_clean();
$expected = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'test_plugin' . DS . 'webroot' . DS . 'root.js'); $expected = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'TestPlugin' . DS . 'webroot' . DS . 'root.js');
$this->assertEqual($result, $expected); $this->assertEqual($result, $expected);
ob_start(); ob_start();
$Dispatcher->dispatch(new CakeRequest('test_plugin/flash/plugin_test.swf')); $Dispatcher->dispatch(new CakeRequest('test_plugin/flash/plugin_test.swf'));
$result = ob_get_clean(); $result = ob_get_clean();
$file = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'test_plugin' . DS . 'webroot' . DS . 'flash' . DS . 'plugin_test.swf'); $file = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'TestPlugin' . DS . 'webroot' . DS . 'flash' . DS . 'plugin_test.swf');
$this->assertEqual($file, $result); $this->assertEqual($file, $result);
$this->assertEqual('this is just a test to load swf file from the plugin.', $result); $this->assertEqual('this is just a test to load swf file from the plugin.', $result);
ob_start(); ob_start();
$Dispatcher->dispatch(new CakeRequest('test_plugin/pdfs/plugin_test.pdf')); $Dispatcher->dispatch(new CakeRequest('test_plugin/pdfs/plugin_test.pdf'));
$result = ob_get_clean(); $result = ob_get_clean();
$file = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'test_plugin' . DS . 'webroot' . DS . 'pdfs' . DS . 'plugin_test.pdf'); $file = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'TestPlugin' . DS . 'webroot' . DS . 'pdfs' . DS . 'plugin_test.pdf');
$this->assertEqual($file, $result); $this->assertEqual($file, $result);
$this->assertEqual('this is just a test to load pdf file from the plugin.', $result); $this->assertEqual('this is just a test to load pdf file from the plugin.', $result);
@ -1299,7 +1297,7 @@ class DispatcherTest extends CakeTestCase {
ob_start(); ob_start();
$Dispatcher->asset('test_plugin/img/cake.icon.gif'); $Dispatcher->asset('test_plugin/img/cake.icon.gif');
$result = ob_get_clean(); $result = ob_get_clean();
$file = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'test_plugin' .DS . 'webroot' . DS . 'img' . DS . 'cake.icon.gif'); $file = file_get_contents(LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'TestPlugin' .DS . 'webroot' . DS . 'img' . DS . 'cake.icon.gif');
$this->assertEqual($file, $result); $this->assertEqual($file, $result);
ob_start(); ob_start();

View file

@ -42,6 +42,16 @@ class RouterTest extends CakeTestCase {
Configure::write('Routing', array('admin' => null, 'prefixes' => array())); Configure::write('Routing', array('admin' => null, 'prefixes' => array()));
} }
/**
* tearDown method
*
* @return void
*/
public function tearDown() {
parent::tearDown();
CakePlugin::unload();
}
/** /**
* testFullBaseURL method * testFullBaseURL method
* *
@ -1179,7 +1189,7 @@ class RouterTest extends CakeTestCase {
LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS
) )
), true); ), true);
App::objects('plugin', null, false); CakePlugin::loadAll();
Router::reload(); Router::reload();
$request = new CakeRequest(); $request = new CakeRequest();
@ -2204,7 +2214,7 @@ class RouterTest extends CakeTestCase {
LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS LIBS . 'tests' . DS . 'test_app' . DS . 'plugins' . DS
) )
), true); ), true);
App::objects('plugin', null, false); CakePlugin::loadAll();
Router::reload(); Router::reload();
$result = Router::url(array('plugin' => 'plugin_js', 'controller' => 'js_file', 'action' => 'index')); $result = Router::url(array('plugin' => 'plugin_js', 'controller' => 'js_file', 'action' => 'index'));