Permalink
Browse files

Splitting apart the Scaffold and ScaffoldView tests.

Fixes #1985
  • Loading branch information...
1 parent 4378bb6 commit 09e7f1d491764b92db367b3442d0a6363f9e88e4 @markstory markstory committed Sep 17, 2011
View
538 lib/Cake/Test/Case/Controller/ScaffoldTest.php
@@ -17,9 +17,13 @@
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
*/
+App::uses('Router', 'Routing');
App::uses('Controller', 'Controller');
App::uses('Scaffold', 'Controller');
App::uses('ScaffoldView', 'View');
+App::uses('AppModel', 'Model');
+
+require_once dirname(dirname(__FILE__)) . DS . 'Model' . DS . 'models.php';
/**
* ScaffoldMockController class
@@ -101,541 +105,7 @@ function getParams() {
}
}
-/**
- * ScaffoldMock class
- *
- * @package Cake.Test.Case.Controller
@ravage84
CakePHP member
ravage84 added a line comment May 29, 2013

Shouldn't that be Cake.Test.Case.View.?
All other cases have Cake.Test.Case.View defined.
I guess that is a leftover from before splitting

@markstory
CakePHP member
markstory added a line comment May 29, 2013

It really doesn't matter, the package tags aren't used for anything really.

@ravage84
CakePHP member
ravage84 added a line comment May 29, 2013

Well, what if someone generates the API docs with something else than https://github.com/cakephp/api_generator ?
For example with ApiGen or phpDocumentator (2).
Those care about the package defs.

@ADmad
CakePHP member
ADmad added a line comment May 29, 2013

@ravage84 CakePHP itself uses ApiGen now 😄

@ravage84
CakePHP member
ravage84 added a line comment May 29, 2013

Just noticed that i did my remark on the wrong file... should have been lib/Cake/Test/Case/View/ScaffoldViewTest.php.

Fixed it:
#1311

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
- */
-class ScaffoldMock extends CakeTestModel {
-
-/**
- * useTable property
- *
- * @var string 'posts'
- */
- public $useTable = 'articles';
-
-/**
- * belongsTo property
- *
- * @var array
- */
- public $belongsTo = array(
- 'User' => array(
- 'className' => 'ScaffoldUser',
- 'foreignKey' => 'user_id',
- )
- );
-
-/**
- * hasMany property
- *
- * @var array
- */
- public $hasMany = array(
- 'Comment' => array(
- 'className' => 'ScaffoldComment',
- 'foreignKey' => 'article_id',
- )
- );
-/**
- * hasAndBelongsToMany property
- *
- * @var string
- */
- public $hasAndBelongsToMany = array(
- 'ScaffoldTag' => array(
- 'className' => 'ScaffoldTag',
- 'foreignKey' => 'something_id',
- 'associationForeignKey' => 'something_else_id',
- 'joinTable' => 'join_things'
- )
- );
-}
-
-/**
- * ScaffoldUser class
- *
- * @package Cake.Test.Case.Controller
- */
-class ScaffoldUser extends CakeTestModel {
-
-/**
- * useTable property
- *
- * @var string 'posts'
- */
- public $useTable = 'users';
-
-/**
- * hasMany property
- *
- * @var array
- */
- public $hasMany = array(
- 'Article' => array(
- 'className' => 'ScaffoldMock',
- 'foreignKey' => 'article_id',
- )
- );
-}
-
-/**
- * ScaffoldComment class
- *
- * @package Cake.Test.Case.Controller
- */
-class ScaffoldComment extends CakeTestModel {
-
-/**
- * useTable property
- *
- * @var string 'posts'
- */
- public $useTable = 'comments';
-/**
- * belongsTo property
- *
- * @var array
- */
- public $belongsTo = array(
- 'Article' => array(
- 'className' => 'ScaffoldMock',
- 'foreignKey' => 'article_id',
- )
- );
-}
-
-/**
- * ScaffoldTag class
- *
- * @package Cake.Test.Case.Controller
- */
-class ScaffoldTag extends CakeTestModel {
-/**
- * useTable property
- *
- * @var string 'posts'
- */
- public $useTable = 'tags';
-}
-/**
- * TestScaffoldView class
- *
- * @package Cake.Test.Case.Controller
- */
-class TestScaffoldView extends ScaffoldView {
-
-/**
- * testGetFilename method
- *
- * @param mixed $action
- * @return void
- */
- public function testGetFilename($action) {
- return $this->_getViewFileName($action);
- }
-}
-
-/**
- * ScaffoldViewTest class
- *
- * @package Cake.Test.Case.Controller
- */
-class ScaffoldViewTest extends CakeTestCase {
-
-/**
- * fixtures property
- *
- * @var array
- */
- public $fixtures = array('core.article', 'core.user', 'core.comment', 'core.join_thing', 'core.tag');
-
-/**
- * setUp method
- *
- * @return void
- */
- public function setUp() {
- parent::setUp();
- $this->request = new CakeRequest(null, false);
- $this->Controller = new ScaffoldMockController($this->request);
- $this->Controller->response = $this->getMock('CakeResponse', array('_sendHeader'));
-
- App::build(array(
- 'View' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'View' . DS),
- 'plugins' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS)
- ));
- CakePlugin::load('TestPlugin');
- }
-
-/**
- * teardown method
- *
- * @return void
- */
- public function tearDown() {
- parent::tearDown();
- unset($this->Controller, $this->request);
- CakePlugin::unload();
- }
-
-/**
- * testGetViewFilename method
- *
- * @return void
- */
- public function testGetViewFilename() {
- $_admin = Configure::read('Routing.prefixes');
- Configure::write('Routing.prefixes', array('admin'));
-
- $this->Controller->request->params['action'] = 'index';
- $ScaffoldView = new TestScaffoldView($this->Controller);
- $result = $ScaffoldView->testGetFilename('index');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'index.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('edit');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('add');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('view');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'view.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('admin_index');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'index.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('admin_view');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'view.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('admin_edit');
- $expected =CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('admin_add');
- $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('error');
- $expected = CAKE . 'View' . DS . 'Errors' . DS . 'scaffold_error.ctp';
- $this->assertEqual($expected, $result);
-
- $Controller = new ScaffoldMockController($this->request);
- $Controller->scaffold = 'admin';
- $Controller->viewPath = 'Posts';
- $Controller->request['action'] = 'admin_edit';
-
- $ScaffoldView = new TestScaffoldView($Controller);
- $result = $ScaffoldView->testGetFilename('admin_edit');
- $expected = CAKE . 'Test' . DS . 'test_app' .DS . 'View' . DS . 'Posts' . DS . 'scaffold.form.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('edit');
- $expected = CAKE . 'Test' . DS . 'test_app' .DS . 'View' . DS . 'Posts' . DS . 'scaffold.form.ctp';
- $this->assertEqual($expected, $result);
-
- $Controller = new ScaffoldMockController($this->request);
- $Controller->scaffold = 'admin';
- $Controller->viewPath = 'Tests';
- $Controller->request->addParams(array(
- 'plugin' => 'test_plugin',
- 'action' => 'admin_add',
- 'admin' => true
- ));
- $Controller->plugin = 'TestPlugin';
-
- $ScaffoldView = new TestScaffoldView($Controller);
- $result = $ScaffoldView->testGetFilename('admin_add');
- $expected = CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin'
- . DS .'TestPlugin' . DS . 'View' . DS . 'Tests' . DS . 'scaffold.form.ctp';
- $this->assertEqual($expected, $result);
-
- $result = $ScaffoldView->testGetFilename('add');
- $expected = CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin'
- . DS .'TestPlugin' . DS . 'View' . DS . 'Tests' . DS . 'scaffold.form.ctp';
- $this->assertEqual($expected, $result);
-
- Configure::write('Routing.prefixes', $_admin);
- }
-
-/**
- * test getting the view file name for themed scaffolds.
- *
- * @return void
- */
- public function testGetViewFileNameWithTheme() {
- $this->Controller->request['action'] = 'index';
- $this->Controller->viewPath = 'Posts';
- $this->Controller->theme = 'TestTheme';
- $ScaffoldView = new TestScaffoldView($this->Controller);
-
- $result = $ScaffoldView->testGetFilename('index');
- $expected = CAKE . 'Test' . DS . 'test_app' . DS . 'View' . DS
- . 'Themed' . DS . 'TestTheme' . DS . 'Posts' . DS . 'scaffold.index.ctp';
- $this->assertEqual($expected, $result);
- }
-
-/**
- * test default index scaffold generation
- *
- * @return void
- */
- public function testIndexScaffold() {
- $params = array(
- 'plugin' => null,
- 'pass' => array(),
- 'form' => array(),
- 'named' => array(),
- 'url' => array('url' =>'scaffold_mock'),
- 'controller' => 'scaffold_mock',
- 'action' => 'index',
- );
- $this->Controller->request->addParams($params);
- $this->Controller->request->webroot = '/';
- $this->Controller->request->base = '';
- $this->Controller->request->here = '/scaffold_mock/index';
-
- //set router.
- Router::reload();
- Router::setRequestInfo($this->Controller->request);
-
- $this->Controller->constructClasses();
- ob_start();
- new Scaffold($this->Controller, $this->Controller->request);
- $this->Controller->response->send();
- $result = ob_get_clean();
-
- $this->assertPattern('#<h2>Scaffold Mock</h2>#', $result);
- $this->assertPattern('#<table cellpadding="0" cellspacing="0">#', $result);
-
- $this->assertPattern('#<a href="/scaffold_users/view/1">1</a>#', $result); //belongsTo links
- $this->assertPattern('#<li><a href="/scaffold_mock/add">New Scaffold Mock</a></li>#', $result);
- $this->assertPattern('#<li><a href="/scaffold_users">List Scaffold Users</a></li>#', $result);
- $this->assertPattern('#<li><a href="/scaffold_comments/add">New Comment</a></li>#', $result);
- }
-
-/**
- * test default view scaffold generation
- *
- * @return void
- */
- public function testViewScaffold() {
- $this->Controller->request->base = '';
- $this->Controller->request->here = '/scaffold_mock';
- $this->Controller->request->webroot = '/';
- $params = array(
- 'plugin' => null,
- 'pass' => array(1),
- 'form' => array(),
- 'named' => array(),
- 'url' => array('url' => 'scaffold_mock/view/1'),
- 'controller' => 'scaffold_mock',
- 'action' => 'view',
- );
- $this->Controller->request->addParams($params);
-
- //set router.
- Router::reload();
- Router::setRequestInfo($this->Controller->request);
- $this->Controller->constructClasses();
-
- ob_start();
- new Scaffold($this->Controller, $this->Controller->request);
- $this->Controller->response->send();
- $result = ob_get_clean();
-
- $this->assertPattern('/<h2>View Scaffold Mock<\/h2>/', $result);
- $this->assertPattern('/<dl>/', $result);
- //TODO: add specific tests for fields.
- $this->assertPattern('/<a href="\/scaffold_users\/view\/1">1<\/a>/', $result); //belongsTo links
- $this->assertPattern('/<li><a href="\/scaffold_mock\/edit\/1">Edit Scaffold Mock<\/a>\s<\/li>/', $result);
- $this->assertPattern('/<li><a href="\/scaffold_mock\/delete\/1"[^>]*>Delete Scaffold Mock<\/a>\s*<\/li>/', $result);
- //check related table
- $this->assertPattern('/<div class="related">\s*<h3>Related Scaffold Comments<\/h3>\s*<table cellpadding="0" cellspacing="0">/', $result);
- $this->assertPattern('/<li><a href="\/scaffold_comments\/add">New Comment<\/a><\/li>/', $result);
- $this->assertNoPattern('/<th>JoinThing<\/th>/', $result);
- }
-
-/**
- * test default view scaffold generation
- *
- * @return void
- */
- public function testEditScaffold() {
- $this->Controller->request->base = '';
- $this->Controller->request->webroot = '/';
- $this->Controller->request->here = '/scaffold_mock/edit/1';
-
- $params = array(
- 'plugin' => null,
- 'pass' => array(1),
- 'form' => array(),
- 'named' => array(),
- 'url' => array('url' =>'scaffold_mock'),
- 'controller' => 'scaffold_mock',
- 'action' => 'edit',
- );
- $this->Controller->request->addParams($params);
-
- //set router.
- Router::reload();
- Router::setRequestInfo($this->Controller->request);
- $this->Controller->constructClasses();
-
- ob_start();
- new Scaffold($this->Controller, $this->Controller->request);
- $this->Controller->response->send();
- $result = ob_get_clean();
-
- $this->assertContains('<form action="/scaffold_mock/edit/1" id="ScaffoldMockEditForm" method="post"', $result);
- $this->assertContains('<legend>Edit Scaffold Mock</legend>', $result);
-
- $this->assertContains('input type="hidden" name="data[ScaffoldMock][id]" value="1" id="ScaffoldMockId"', $result);
- $this->assertContains('select name="data[ScaffoldMock][user_id]" id="ScaffoldMockUserId"', $result);
- $this->assertContains('input name="data[ScaffoldMock][title]" maxlength="255" type="text" value="First Article" id="ScaffoldMockTitle"', $result);
- $this->assertContains('input name="data[ScaffoldMock][published]" maxlength="1" type="text" value="Y" id="ScaffoldMockPublished"', $result);
- $this->assertContains('textarea name="data[ScaffoldMock][body]" cols="30" rows="6" id="ScaffoldMockBody"', $result);
- $this->assertPattern('/<a href="\#" onclick="if[^>]*>Delete<\/a><\/li>/', $result);
- }
-
-/**
- * Test Admin Index Scaffolding.
- *
- * @return void
- */
- public function testAdminIndexScaffold() {
- $_backAdmin = Configure::read('Routing.prefixes');
-
- Configure::write('Routing.prefixes', array('admin'));
- $params = array(
- 'plugin' => null,
- 'pass' => array(),
- 'form' => array(),
- 'named' => array(),
- 'prefix' => 'admin',
- 'url' => array('url' =>'admin/scaffold_mock'),
- 'controller' => 'scaffold_mock',
- 'action' => 'admin_index',
- 'admin' => 1,
- );
- $this->Controller->request->base = '';
- $this->Controller->request->webroot = '/';
- $this->Controller->request->here = '/admin/scaffold_mock';
- $this->Controller->request->addParams($params);
-
- //reset, and set router.
- Router::reload();
- Router::setRequestInfo($this->Controller->request);
-
- $this->Controller->scaffold = 'admin';
- $this->Controller->constructClasses();
-
- ob_start();
- $Scaffold = new Scaffold($this->Controller, $this->Controller->request);
- $this->Controller->response->send();
- $result = ob_get_clean();
-
- $this->assertPattern('/<h2>Scaffold Mock<\/h2>/', $result);
- $this->assertPattern('/<table cellpadding="0" cellspacing="0">/', $result);
- //TODO: add testing for table generation
- $this->assertPattern('/<li><a href="\/admin\/scaffold_mock\/add">New Scaffold Mock<\/a><\/li>/', $result);
-
- Configure::write('Routing.prefixes', $_backAdmin);
- }
-
-/**
- * Test Admin Index Scaffolding.
- *
- * @return void
- */
- public function testAdminEditScaffold() {
- Configure::write('Routing.prefixes', array('admin'));
- $params = array(
- 'plugin' => null,
- 'pass' => array(1),
- 'form' => array(),
- 'named' => array(),
- 'prefix' => 'admin',
- 'url' => array('url' =>'admin/scaffold_mock/edit/1'),
- 'controller' => 'scaffold_mock',
- 'action' => 'admin_edit',
- 'admin' => 1,
- );
- $this->Controller->request->base = '';
- $this->Controller->request->webroot = '/';
- $this->Controller->request->here = '/admin/scaffold_mock/edit/1';
- $this->Controller->request->addParams($params);
-
- //reset, and set router.
- Router::reload();
- Router::setRequestInfo($this->Controller->request);
-
- $this->Controller->scaffold = 'admin';
- $this->Controller->constructClasses();
-
- ob_start();
- $Scaffold = new Scaffold($this->Controller, $this->Controller->request);
- $this->Controller->response->send();
- $result = ob_get_clean();
-
- $this->assertPattern('#admin/scaffold_mock/edit/1#', $result);
- $this->assertPattern('#Scaffold Mock#', $result);
- }
-
-/**
- * Test Admin Index Scaffolding.
- *
- * @return void
- */
- public function testMultiplePrefixScaffold() {
- $_backAdmin = Configure::read('Routing.prefixes');
-
- Configure::write('Routing.prefixes', array('admin', 'member'));
- $params = array(
- 'plugin' => null,
- 'pass' => array(),
- 'form' => array(),
- 'named' => array(),
- 'prefix' => 'member',
- 'url' => array('url' =>'member/scaffold_mock'),
- 'controller' => 'scaffold_mock',
- 'action' => 'member_index',
- 'member' => 1,
- );
- $this->Controller->request->base = '';
- $this->Controller->request->webroot = '/';
- $this->Controller->request->here = '/member/scaffold_mock';
- $this->Controller->request->addParams($params);
-
- //reset, and set router.
- Router::reload();
- Router::setRequestInfo($this->Controller->request);
-
- $this->Controller->scaffold = 'member';
- $this->Controller->constructClasses();
-
- ob_start();
- $Scaffold = new Scaffold($this->Controller, $this->Controller->request);
- $this->Controller->response->send();
- $result = ob_get_clean();
-
- $this->assertPattern('/<h2>Scaffold Mock<\/h2>/', $result);
- $this->assertPattern('/<table cellpadding="0" cellspacing="0">/', $result);
- //TODO: add testing for table generation
- $this->assertPattern('/<li><a href="\/member\/scaffold_mock\/add">New Scaffold Mock<\/a><\/li>/', $result);
-
- Configure::write('Routing.prefixes', $_backAdmin);
- }
-
-}
/**
* Scaffold Test class
View
119 lib/Cake/Test/Case/Model/models.php
@@ -4401,3 +4401,122 @@ class PrefixTestUseTableModel extends CakeTestModel {
var $useTable = 'prefix_tests';
}
+/**
+ * ScaffoldMock class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class ScaffoldMock extends CakeTestModel {
+
+/**
+ * useTable property
+ *
+ * @var string 'posts'
+ */
+ public $useTable = 'articles';
+
+/**
+ * belongsTo property
+ *
+ * @var array
+ */
+ public $belongsTo = array(
+ 'User' => array(
+ 'className' => 'ScaffoldUser',
+ 'foreignKey' => 'user_id',
+ )
+ );
+
+/**
+ * hasMany property
+ *
+ * @var array
+ */
+ public $hasMany = array(
+ 'Comment' => array(
+ 'className' => 'ScaffoldComment',
+ 'foreignKey' => 'article_id',
+ )
+ );
+/**
+ * hasAndBelongsToMany property
+ *
+ * @var string
+ */
+ public $hasAndBelongsToMany = array(
+ 'ScaffoldTag' => array(
+ 'className' => 'ScaffoldTag',
+ 'foreignKey' => 'something_id',
+ 'associationForeignKey' => 'something_else_id',
+ 'joinTable' => 'join_things'
+ )
+ );
+}
+
+/**
+ * ScaffoldUser class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class ScaffoldUser extends CakeTestModel {
+
+/**
+ * useTable property
+ *
+ * @var string 'posts'
+ */
+ public $useTable = 'users';
+
+/**
+ * hasMany property
+ *
+ * @var array
+ */
+ public $hasMany = array(
+ 'Article' => array(
+ 'className' => 'ScaffoldMock',
+ 'foreignKey' => 'article_id',
+ )
+ );
+}
+
+/**
+ * ScaffoldComment class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class ScaffoldComment extends CakeTestModel {
+
+/**
+ * useTable property
+ *
+ * @var string 'posts'
+ */
+ public $useTable = 'comments';
+
+/**
+ * belongsTo property
+ *
+ * @var array
+ */
+ public $belongsTo = array(
+ 'Article' => array(
+ 'className' => 'ScaffoldMock',
+ 'foreignKey' => 'article_id',
+ )
+ );
+}
+
+/**
+ * ScaffoldTag class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class ScaffoldTag extends CakeTestModel {
+/**
+ * useTable property
+ *
+ * @var string 'posts'
+ */
+ public $useTable = 'tags';
+}
View
462 lib/Cake/Test/Case/View/ScaffoldViewTest.php
@@ -0,0 +1,462 @@
+<?php
+/**
+ * ScaffoldViewTest file
+ *
+ * PHP 5
+ *
+ * CakePHP(tm) Tests <http://book.cakephp.org/view/1196/Testing>
+ * Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org)
+ *
+ * Licensed under The MIT License
+ * Redistributions of files must retain the above copyright notice
+ *
+ * @copyright Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org)
+ * @link http://book.cakephp.org/view/1196/Testing CakePHP(tm) Tests
+ * @package Cake.Test.Case.Controller
+ * @since CakePHP(tm) v 2.0
+ * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
+ */
+App::uses('Controller', 'Controller');
+App::uses('Scaffold', 'Controller');
+App::uses('ScaffoldView', 'View');
+App::uses('AppModel', 'Model');
+
+require_once dirname(dirname(__FILE__)) . DS . 'Model' . DS . 'models.php';
+
+/**
+ * TestScaffoldView class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class TestScaffoldView extends ScaffoldView {
+
+/**
+ * testGetFilename method
+ *
+ * @param mixed $action
+ * @return void
+ */
+ public function testGetFilename($action) {
+ return $this->_getViewFileName($action);
+ }
+}
+
+/**
+ * ScaffoldViewMockController class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class ScaffoldViewMockController extends Controller {
+
+/**
+ * name property
+ *
+ * @var string 'ScaffoldMock'
+ */
+ public $name = 'ScaffoldMock';
+
+/**
+ * scaffold property
+ *
+ * @var mixed
+ */
+ public $scaffold;
+}
+
+/**
+ * ScaffoldViewTest class
+ *
+ * @package Cake.Test.Case.Controller
+ */
+class ScaffoldViewTest extends CakeTestCase {
+
+/**
+ * fixtures property
+ *
+ * @var array
+ */
+ public $fixtures = array('core.article', 'core.user', 'core.comment', 'core.join_thing', 'core.tag');
+
+/**
+ * setUp method
+ *
+ * @return void
+ */
+ public function setUp() {
+ parent::setUp();
+ $this->request = new CakeRequest(null, false);
+ $this->Controller = new ScaffoldViewMockController($this->request);
+ $this->Controller->response = $this->getMock('CakeResponse', array('_sendHeader'));
+
+ App::build(array(
+ 'View' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'View' . DS),
+ 'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS)
+ ));
+ CakePlugin::load('TestPlugin');
+ }
+
+/**
+ * teardown method
+ *
+ * @return void
+ */
+ public function tearDown() {
+ unset($this->Controller, $this->request);
+ parent::tearDown();
+ }
+
+/**
+ * testGetViewFilename method
+ *
+ * @return void
+ */
+ public function testGetViewFilename() {
+ $_admin = Configure::read('Routing.prefixes');
+ Configure::write('Routing.prefixes', array('admin'));
+
+ $this->Controller->request->params['action'] = 'index';
+ $ScaffoldView = new TestScaffoldView($this->Controller);
+ $result = $ScaffoldView->testGetFilename('index');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'index.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('edit');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('add');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('view');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'view.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('admin_index');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'index.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('admin_view');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'view.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('admin_edit');
+ $expected =CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('admin_add');
+ $expected = CAKE . 'View' . DS . 'Scaffolds' . DS . 'form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('error');
+ $expected = CAKE . 'View' . DS . 'Errors' . DS . 'scaffold_error.ctp';
+ $this->assertEqual($expected, $result);
+
+ $Controller = new ScaffoldViewMockController($this->request);
+ $Controller->scaffold = 'admin';
+ $Controller->viewPath = 'Posts';
+ $Controller->request['action'] = 'admin_edit';
+
+ $ScaffoldView = new TestScaffoldView($Controller);
+ $result = $ScaffoldView->testGetFilename('admin_edit');
+ $expected = CAKE . 'Test' . DS . 'test_app' .DS . 'View' . DS . 'Posts' . DS . 'scaffold.form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('edit');
+ $expected = CAKE . 'Test' . DS . 'test_app' .DS . 'View' . DS . 'Posts' . DS . 'scaffold.form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $Controller = new ScaffoldViewMockController($this->request);
+ $Controller->scaffold = 'admin';
+ $Controller->viewPath = 'Tests';
+ $Controller->request->addParams(array(
+ 'plugin' => 'test_plugin',
+ 'action' => 'admin_add',
+ 'admin' => true
+ ));
+ $Controller->plugin = 'TestPlugin';
+
+ $ScaffoldView = new TestScaffoldView($Controller);
+ $result = $ScaffoldView->testGetFilename('admin_add');
+ $expected = CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin'
+ . DS .'TestPlugin' . DS . 'View' . DS . 'Tests' . DS . 'scaffold.form.ctp';
+ $this->assertEqual($expected, $result);
+
+ $result = $ScaffoldView->testGetFilename('add');
+ $expected = CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin'
+ . DS .'TestPlugin' . DS . 'View' . DS . 'Tests' . DS . 'scaffold.form.ctp';
+ $this->assertEqual($expected, $result);
+
+ Configure::write('Routing.prefixes', $_admin);
+ }
+
+/**
+ * test getting the view file name for themed scaffolds.
+ *
+ * @return void
+ */
+ public function testGetViewFileNameWithTheme() {
+ $this->Controller->request['action'] = 'index';
+ $this->Controller->viewPath = 'Posts';
+ $this->Controller->theme = 'TestTheme';
+ $ScaffoldView = new TestScaffoldView($this->Controller);
+
+ $result = $ScaffoldView->testGetFilename('index');
+ $expected = CAKE . 'Test' . DS . 'test_app' . DS . 'View' . DS
+ . 'Themed' . DS . 'TestTheme' . DS . 'Posts' . DS . 'scaffold.index.ctp';
+ $this->assertEqual($expected, $result);
+ }
+
+/**
+ * test default index scaffold generation
+ *
+ * @return void
+ */
+ public function testIndexScaffold() {
+ $params = array(
+ 'plugin' => null,
+ 'pass' => array(),
+ 'form' => array(),
+ 'named' => array(),
+ 'url' => array('url' =>'scaffold_mock'),
+ 'controller' => 'scaffold_mock',
+ 'action' => 'index',
+ );
+ $this->Controller->request->addParams($params);
+ $this->Controller->request->webroot = '/';
+ $this->Controller->request->base = '';
+ $this->Controller->request->here = '/scaffold_mock/index';
+
+ //set router.
+ Router::reload();
+ Router::setRequestInfo($this->Controller->request);
+
+ $this->Controller->constructClasses();
+ ob_start();
+ new Scaffold($this->Controller, $this->Controller->request);
+ $this->Controller->response->send();
+ $result = ob_get_clean();
+
+ $this->assertPattern('#<h2>Scaffold Mock</h2>#', $result);
+ $this->assertPattern('#<table cellpadding="0" cellspacing="0">#', $result);
+
+ $this->assertPattern('#<a href="/scaffold_users/view/1">1</a>#', $result); //belongsTo links
+ $this->assertPattern('#<li><a href="/scaffold_mock/add">New Scaffold Mock</a></li>#', $result);
+ $this->assertPattern('#<li><a href="/scaffold_users">List Scaffold Users</a></li>#', $result);
+ $this->assertPattern('#<li><a href="/scaffold_comments/add">New Comment</a></li>#', $result);
+ }
+
+/**
+ * test default view scaffold generation
+ *
+ * @return void
+ */
+ public function testViewScaffold() {
+ $this->Controller->request->base = '';
+ $this->Controller->request->here = '/scaffold_mock';
+ $this->Controller->request->webroot = '/';
+ $params = array(
+ 'plugin' => null,
+ 'pass' => array(1),
+ 'form' => array(),
+ 'named' => array(),
+ 'url' => array('url' => 'scaffold_mock/view/1'),
+ 'controller' => 'scaffold_mock',
+ 'action' => 'view',
+ );
+ $this->Controller->request->addParams($params);
+
+ //set router.
+ Router::reload();
+ Router::setRequestInfo($this->Controller->request);
+ $this->Controller->constructClasses();
+
+ ob_start();
+ new Scaffold($this->Controller, $this->Controller->request);
+ $this->Controller->response->send();
+ $result = ob_get_clean();
+
+ $this->assertPattern('/<h2>View Scaffold Mock<\/h2>/', $result);
+ $this->assertPattern('/<dl>/', $result);
+ //TODO: add specific tests for fields.
+ $this->assertPattern('/<a href="\/scaffold_users\/view\/1">1<\/a>/', $result); //belongsTo links
+ $this->assertPattern('/<li><a href="\/scaffold_mock\/edit\/1">Edit Scaffold Mock<\/a>\s<\/li>/', $result);
+ $this->assertPattern('/<li><a href="\/scaffold_mock\/delete\/1"[^>]*>Delete Scaffold Mock<\/a>\s*<\/li>/', $result);
+ //check related table
+ $this->assertPattern('/<div class="related">\s*<h3>Related Scaffold Comments<\/h3>\s*<table cellpadding="0" cellspacing="0">/', $result);
+ $this->assertPattern('/<li><a href="\/scaffold_comments\/add">New Comment<\/a><\/li>/', $result);
+ $this->assertNoPattern('/<th>JoinThing<\/th>/', $result);
+ }
+
+/**
+ * test default view scaffold generation
+ *
+ * @return void
+ */
+ public function testEditScaffold() {
+ $this->Controller->request->base = '';
+ $this->Controller->request->webroot = '/';
+ $this->Controller->request->here = '/scaffold_mock/edit/1';
+
+ $params = array(
+ 'plugin' => null,
+ 'pass' => array(1),
+ 'form' => array(),
+ 'named' => array(),
+ 'url' => array('url' =>'scaffold_mock'),
+ 'controller' => 'scaffold_mock',
+ 'action' => 'edit',
+ );
+ $this->Controller->request->addParams($params);
+
+ //set router.
+ Router::reload();
+ Router::setRequestInfo($this->Controller->request);
+ $this->Controller->constructClasses();
+
+ ob_start();
+ new Scaffold($this->Controller, $this->Controller->request);
+ $this->Controller->response->send();
+ $result = ob_get_clean();
+
+ $this->assertContains('<form action="/scaffold_mock/edit/1" id="ScaffoldMockEditForm" method="post"', $result);
+ $this->assertContains('<legend>Edit Scaffold Mock</legend>', $result);
+
+ $this->assertContains('input type="hidden" name="data[ScaffoldMock][id]" value="1" id="ScaffoldMockId"', $result);
+ $this->assertContains('select name="data[ScaffoldMock][user_id]" id="ScaffoldMockUserId"', $result);
+ $this->assertContains('input name="data[ScaffoldMock][title]" maxlength="255" type="text" value="First Article" id="ScaffoldMockTitle"', $result);
+ $this->assertContains('input name="data[ScaffoldMock][published]" maxlength="1" type="text" value="Y" id="ScaffoldMockPublished"', $result);
+ $this->assertContains('textarea name="data[ScaffoldMock][body]" cols="30" rows="6" id="ScaffoldMockBody"', $result);
+ $this->assertPattern('/<a href="\#" onclick="if[^>]*>Delete<\/a><\/li>/', $result);
+ }
+
+/**
+ * Test Admin Index Scaffolding.
+ *
+ * @return void
+ */
+ public function testAdminIndexScaffold() {
+ $_backAdmin = Configure::read('Routing.prefixes');
+
+ Configure::write('Routing.prefixes', array('admin'));
+ $params = array(
+ 'plugin' => null,
+ 'pass' => array(),
+ 'form' => array(),
+ 'named' => array(),
+ 'prefix' => 'admin',
+ 'url' => array('url' =>'admin/scaffold_mock'),
+ 'controller' => 'scaffold_mock',
+ 'action' => 'admin_index',
+ 'admin' => 1,
+ );
+ $this->Controller->request->base = '';
+ $this->Controller->request->webroot = '/';
+ $this->Controller->request->here = '/admin/scaffold_mock';
+ $this->Controller->request->addParams($params);
+
+ //reset, and set router.
+ Router::reload();
+ Router::setRequestInfo($this->Controller->request);
+
+ $this->Controller->scaffold = 'admin';
+ $this->Controller->constructClasses();
+
+ ob_start();
+ $Scaffold = new Scaffold($this->Controller, $this->Controller->request);
+ $this->Controller->response->send();
+ $result = ob_get_clean();
+
+ $this->assertPattern('/<h2>Scaffold Mock<\/h2>/', $result);
+ $this->assertPattern('/<table cellpadding="0" cellspacing="0">/', $result);
+ //TODO: add testing for table generation
+ $this->assertPattern('/<li><a href="\/admin\/scaffold_mock\/add">New Scaffold Mock<\/a><\/li>/', $result);
+
+ Configure::write('Routing.prefixes', $_backAdmin);
+ }
+
+/**
+ * Test Admin Index Scaffolding.
+ *
+ * @return void
+ */
+ public function testAdminEditScaffold() {
+ Configure::write('Routing.prefixes', array('admin'));
+ $params = array(
+ 'plugin' => null,
+ 'pass' => array(1),
+ 'form' => array(),
+ 'named' => array(),
+ 'prefix' => 'admin',
+ 'url' => array('url' =>'admin/scaffold_mock/edit/1'),
+ 'controller' => 'scaffold_mock',
+ 'action' => 'admin_edit',
+ 'admin' => 1,
+ );
+ $this->Controller->request->base = '';
+ $this->Controller->request->webroot = '/';
+ $this->Controller->request->here = '/admin/scaffold_mock/edit/1';
+ $this->Controller->request->addParams($params);
+
+ //reset, and set router.
+ Router::reload();
+ Router::setRequestInfo($this->Controller->request);
+
+ $this->Controller->scaffold = 'admin';
+ $this->Controller->constructClasses();
+
+ ob_start();
+ $Scaffold = new Scaffold($this->Controller, $this->Controller->request);
+ $this->Controller->response->send();
+ $result = ob_get_clean();
+
+ $this->assertPattern('#admin/scaffold_mock/edit/1#', $result);
+ $this->assertPattern('#Scaffold Mock#', $result);
+ }
+
+/**
+ * Test Admin Index Scaffolding.
+ *
+ * @return void
+ */
+ public function testMultiplePrefixScaffold() {
+ $_backAdmin = Configure::read('Routing.prefixes');
+
+ Configure::write('Routing.prefixes', array('admin', 'member'));
+ $params = array(
+ 'plugin' => null,
+ 'pass' => array(),
+ 'form' => array(),
+ 'named' => array(),
+ 'prefix' => 'member',
+ 'url' => array('url' =>'member/scaffold_mock'),
+ 'controller' => 'scaffold_mock',
+ 'action' => 'member_index',
+ 'member' => 1,
+ );
+ $this->Controller->request->base = '';
+ $this->Controller->request->webroot = '/';
+ $this->Controller->request->here = '/member/scaffold_mock';
+ $this->Controller->request->addParams($params);
+
+ //reset, and set router.
+ Router::reload();
+ Router::setRequestInfo($this->Controller->request);
+
+ $this->Controller->scaffold = 'member';
+ $this->Controller->constructClasses();
+
+ ob_start();
+ $Scaffold = new Scaffold($this->Controller, $this->Controller->request);
+ $this->Controller->response->send();
+ $result = ob_get_clean();
+
+ $this->assertPattern('/<h2>Scaffold Mock<\/h2>/', $result);
+ $this->assertPattern('/<table cellpadding="0" cellspacing="0">/', $result);
+ //TODO: add testing for table generation
+ $this->assertPattern('/<li><a href="\/member\/scaffold_mock\/add">New Scaffold Mock<\/a><\/li>/', $result);
+
+ Configure::write('Routing.prefixes', $_backAdmin);
+ }
+
+}

0 comments on commit 09e7f1d

Please sign in to comment.