Permalink
Browse files

Adding test case for ViewTask

  • Loading branch information...
1 parent b301654 commit f1821f563144d4351beb9708cac72ed4707da246 @markstory markstory committed May 30, 2009
Showing with 118 additions and 0 deletions.
  1. +118 −0 cake/tests/cases/console/libs/tasks/view.test.php
View
118 cake/tests/cases/console/libs/tasks/view.test.php
@@ -0,0 +1,118 @@
+<?php
+/* SVN FILE: $Id$ */
+/**
+ * TestTaskTest file
+ *
+ * Test Case for test generation shell task
+ *
+ * PHP versions 4 and 5
+ *
+ * CakePHP : Rapid Development Framework (http://www.cakephp.org)
+ * Copyright 2006-2008, Cake Software Foundation, Inc.
+ *
+ * Licensed under The MIT License
+ * Redistributions of files must retain the above copyright notice.
+ *
+ * @filesource
+ * @copyright Copyright 2006-2008, Cake Software Foundation, Inc.
+ * @link http://www.cakefoundation.org/projects/info/cakephp CakePHP Project
+ * @package cake
+ * @subpackage cake.tests.cases.console.libs.tasks
+ * @since CakePHP v 1.2.0.7726
+ * @version $Revision$
+ * @modifiedby $LastChangedBy$
+ * @lastmodified $Date$
+ * @license http://www.opensource.org/licenses/mit-license.php The MIT License
+ */
+App::import('Core', 'Shell');
+App::import('Core', array('Controller', 'Model'));
+
+if (!defined('DISABLE_AUTO_DISPATCH')) {
+ define('DISABLE_AUTO_DISPATCH', true);
+}
+
+if (!class_exists('ShellDispatcher')) {
+ ob_start();
+ $argv = false;
+ require CAKE . 'console' . DS . 'cake.php';
+ ob_end_clean();
+}
+
+if (!class_exists('TestTask')) {
+ require CAKE . 'console' . DS . 'libs' . DS . 'tasks' . DS . 'view.php';
+ require CAKE . 'console' . DS . 'libs' . DS . 'tasks' . DS . 'template.php';
+}
+
+Mock::generatePartial(
+ 'ShellDispatcher', 'TestTestTaskMockShellDispatcher',
+ array('getInput', 'stdout', 'stderr', '_stop', '_initEnvironment')
+);
+Mock::generatePartial(
+ 'ViewTask', 'MockViewTask',
+ array('in', '_stop', 'err', 'out', 'createFile')
+);
+
+/**
+ * ViewTaskTest class
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.console.libs.tasks
+ */
+class ViewTaskTest extends CakeTestCase {
+
+ var $fixtures = array('core.article', 'core.comment', 'core.articles_tag', 'core.tag');
+/**
+ * setUp method
+ *
+ * @return void
+ * @access public
+ */
+ function startTest() {
+ $this->Dispatcher =& new TestTestTaskMockShellDispatcher();
+ $this->Dispatcher->shellPaths = Configure::read('shellPaths');
+ $this->Task =& new MockViewTask($this->Dispatcher);
+ $this->Task->Dispatch =& $this->Dispatcher;
+ $this->Task->Template =& new TemplateTask($this->Dispatcher);
+ }
+
+/**
+ * tearDown method
+ *
+ * @return void
+ * @access public
+ */
+ function endTest() {
+ ClassRegistry::flush();
+ }
+
+/**
+ * Test getContent and parsing of Templates.
+ *
+ * @return void
+ **/
+ function testGetContent() {
+ $vars = array(
+ 'modelClass' => 'TestViewModel',
+ 'schema' => array(),
+ 'primaryKey' => 'id',
+ 'displayField' => 'name',
+ 'singularVar' => 'testViewModel',
+ 'pluralVar' => 'testViewModels',
+ 'singularHumanName' => 'Test View Model',
+ 'pluralHumanName' => 'Test View Models',
+ 'fields' => array('id', 'name', 'body'),
+ 'associations' => array()
+ );
+ $result = $this->Task->getContent('view', $vars);
+
+ $this->assertPattern('/Delete Test View Model/', $result);
+ $this->assertPattern('/Edit Test View Model/', $result);
+ $this->assertPattern('/List Test View Models/', $result);
+ $this->assertPattern('/New Test View Model/', $result);
+
+ $this->assertPattern('/testViewModel\[\'TestViewModel\'\]\[\'id\'\]/', $result);
+ $this->assertPattern('/testViewModel\[\'TestViewModel\'\]\[\'name\'\]/', $result);
+ $this->assertPattern('/testViewModel\[\'TestViewModel\'\]\[\'body\'\]/', $result);
+ }
+}
+?>

0 comments on commit f1821f5

Please sign in to comment.