khanat-opennel-code/code/web/public_php/webtt/plugins/debug_kit/tests/cases/views/helpers/toolbar.test.php

170 lines
5.1 KiB
PHP

<?php
/**
* Toolbar facade tests.
*
* PHP versions 4 and 5
*
* CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
* Copyright 2005-2010, Cake Software Foundation, Inc. (http://cakefoundation.org)
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice.
*
* @copyright Copyright 2005-2010, Cake Software Foundation, Inc. (http://cakefoundation.org)
* @link http://cakephp.org
* @package debug_kit
* @subpackage debug_kit.tests.views.helpers
* @since DebugKit 0.1
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
**/
App::import('Helper', array('DebugKit.Toolbar'));
App::import('Core', array('View', 'Controller'));
Mock::generate('Helper', 'MockBackendHelper', array('testMethod'));
class ToolbarHelperTestCase extends CakeTestCase {
var $fixtures = array('core.post');
/**
* setUp
*
* @return void
**/
function startTest() {
Configure::write('Cache.disable', false);
Router::connect('/', array('controller' => 'pages', 'action' => 'display', 'home'));
Router::parse('/');
$this->Toolbar =& new ToolbarHelper(array(
'output' => 'MockBackendHelper',
'cacheKey' => 'debug_kit_toolbar_test_case',
'cacheConfig' => 'default'
));
$this->Toolbar->MockBackend = new MockBackendHelper();
$this->Controller =& ClassRegistry::init('Controller');
if (isset($this->_debug)) {
Configure::write('debug', $this->_debug);
}
}
/**
* start Case - switch view paths
*
* @return void
**/
function startCase() {
$this->_viewPaths = App::path('views');
App::build(array(
'views' => array(
TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'views'. DS,
APP . 'plugins' . DS . 'debug_kit' . DS . 'views'. DS,
ROOT . DS . LIBS . 'view' . DS
)), true);
$this->_debug = Configure::read('debug');
}
/**
* test cache writing for views.
*
* @return void
**/
function testCacheWrite() {
$result = $this->Toolbar->writeCache('test', array('stuff', 'to', 'cache'));
$this->assertTrue($result);
}
/**
* Ensure that the cache writing only affects the
* top most level of the history stack. As this is where the current request is stored.
*
* @return void
**/
function testOnlyWritingToFirstElement() {
$values = array(
array('test' => array('content' => array('first', 'values'))),
array('test' => array('content' => array('second', 'values'))),
);
Cache::write('debug_kit_toolbar_test_case', $values, 'default');
$this->Toolbar->writeCache('test', array('new', 'values'));
$result = $this->Toolbar->readCache('test');
$this->assertEqual($result, array('new', 'values'));
$result = $this->Toolbar->readCache('test', 1);
$this->assertEqual($result, array('second', 'values'));
}
/**
* test cache reading for views
*
* @return void
**/
function testCacheRead() {
$result = $this->Toolbar->writeCache('test', array('stuff', 'to', 'cache'));
$this->assertTrue($result, 'Cache write failed %s');
$result = $this->Toolbar->readCache('test');
$this->assertEqual($result, array('stuff', 'to', 'cache'), 'Cache value is wrong %s');
$result = $this->Toolbar->writeCache('test', array('new', 'stuff'));
$this->assertTrue($result, 'Cache write failed %s');
$result = $this->Toolbar->readCache('test');
$this->assertEqual($result, array('new', 'stuff'), 'Cache value is wrong %s');
}
/**
* Test that reading/writing doesn't work with no cache config.
*
* @return void
**/
function testNoCacheConfigPresent() {
$this->Toolbar = new ToolbarHelper(array('output' => 'MockBackendHelper'));
$result = $this->Toolbar->writeCache('test', array('stuff', 'to', 'cache'));
$this->assertFalse($result, 'Writing to cache succeeded with no cache config %s');
$result = $this->Toolbar->readCache('test');
$this->assertFalse($result, 'Reading cache succeeded with no cache config %s');
}
/**
* ensure that getQueryLogs works and writes to the cache so the history panel will
* work.
*
* @return void
*/
function testGetQueryLogs() {
$model =& new Model(array('ds' => 'test_suite', 'table' => 'posts', 'name' => 'Post'));
$model->find('all');
$model->find('first');
$result = $this->Toolbar->getQueryLogs('test_suite', array('cache' => false));
$this->assertTrue(is_array($result));
$this->assertTrue(count($result) >= 2, 'Should be more than 2 queries in the log %s');
$this->assertTrue(isset($result[0]['actions']));
$model->find('first');
Cache::delete('debug_kit_toolbar_test_case', 'default');
$result = $this->Toolbar->getQueryLogs('test_suite', array('cache' => true));
$cached = $this->Toolbar->readCache('sql_log');
$this->assertTrue(isset($cached['test_suite']));
$this->assertEqual($cached['test_suite'][0], $result[0]);
}
/**
* reset the view paths
*
* @return void
**/
function endCase() {
App::build(array('views' => $this->_viewPaths), true);
Cache::delete('debug_kit_toolbar_test_case', 'default');
}
/**
* endTest
*
* @access public
* @return void
*/
function endTest() {
unset($this->Toolbar, $this->Controller);
ClassRegistry::removeObject('view');
ClassRegistry::flush();
}
}