ViewBuilderTest.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  5. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  6. *
  7. * Licensed under The MIT License
  8. * For full copyright and license information, please see the LICENSE.txt
  9. * Redistributions of files must retain the above copyright notice
  10. *
  11. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  12. * @link https://cakephp.org CakePHP(tm) Project
  13. * @since 3.1.0
  14. * @license https://opensource.org/licenses/mit-license.php MIT License
  15. */
  16. namespace Cake\Test\TestCase\View;
  17. use Cake\Http\Response;
  18. use Cake\Http\ServerRequest;
  19. use Cake\TestSuite\TestCase;
  20. use Cake\View\ViewBuilder;
  21. /**
  22. * View builder test case.
  23. */
  24. class ViewBuilderTest extends TestCase
  25. {
  26. public function testSetVar()
  27. {
  28. $builder = new ViewBuilder();
  29. $builder->setVar('testing', 'value');
  30. $this->assertSame('value', $builder->getVar('testing'));
  31. }
  32. public function testSetVars()
  33. {
  34. $builder = new ViewBuilder();
  35. $data = ['test' => 'val', 'foo' => 'bar'];
  36. $builder->setVars($data);
  37. $this->assertEquals($data, $builder->getVars());
  38. $update = ['test' => 'updated'];
  39. $builder->setVars($update);
  40. $this->assertEquals(
  41. ['test' => 'val', 'foo' => 'bar', 'test' => 'updated'],
  42. $builder->getVars()
  43. );
  44. $update = ['overwrite' => 'yes'];
  45. $builder->setVars($update, false);
  46. $this->assertEquals(
  47. ['overwrite' => 'yes'],
  48. $builder->getVars()
  49. );
  50. }
  51. public function testHasVar()
  52. {
  53. $builder = new ViewBuilder();
  54. $this->assertFalse($builder->hasVar('foo'));
  55. $builder->setVar('foo', 'value');
  56. $this->assertTrue($builder->hasVar('foo'));
  57. $builder->setVar('bar', null);
  58. $this->assertTrue($builder->hasVar('bar'));
  59. }
  60. /**
  61. * data provider for string properties.
  62. *
  63. * @return array
  64. */
  65. public function stringPropertyProvider()
  66. {
  67. return [
  68. ['layoutPath', 'Admin/'],
  69. ['templatePath', 'Admin/'],
  70. ['plugin', 'TestPlugin'],
  71. ['layout', 'admin'],
  72. ['theme', 'TestPlugin'],
  73. ['template', 'edit'],
  74. ['name', 'Articles'],
  75. ['className', 'Cake\View\JsonView'],
  76. ];
  77. }
  78. /**
  79. * data provider for boolean properties.
  80. * Format: [key, expectedDefault, newValue]
  81. *
  82. * @return array
  83. */
  84. public function boolPropertyProvider()
  85. {
  86. return [
  87. ['autoLayout', true, false],
  88. ];
  89. }
  90. /**
  91. * data provider for array properties.
  92. *
  93. * @return array
  94. */
  95. public function arrayPropertyProvider()
  96. {
  97. return [
  98. ['helpers', ['Html', 'Form']],
  99. ['options', ['key' => 'value']],
  100. ];
  101. }
  102. /**
  103. * Test string property accessor/mutator methods.
  104. *
  105. * @dataProvider stringPropertyProvider
  106. * @return void
  107. */
  108. public function testStringProperties($property, $value)
  109. {
  110. $get = 'get' . ucfirst($property);
  111. $set = 'set' . ucfirst($property);
  112. $builder = new ViewBuilder();
  113. $this->assertNull($builder->{$get}(), 'Default value should be null');
  114. $this->assertSame($builder, $builder->{$set}($value), 'Setter returns this');
  115. $this->assertSame($value, $builder->{$get}(), 'Getter gets value.');
  116. }
  117. /**
  118. * Test string property accessor/mutator methods.
  119. *
  120. * @dataProvider boolPropertyProvider
  121. * @return void
  122. */
  123. public function testBoolProperties($property, $default, $value)
  124. {
  125. $set = 'enable' . ucfirst($property);
  126. $get = 'is' . ucfirst($property) . 'Enabled';
  127. $builder = new ViewBuilder();
  128. $this->assertSame($default, $builder->{$get}(), 'Default value not as expected');
  129. $this->assertSame($builder, $builder->{$set}($value), 'Setter returns this');
  130. $this->assertSame($value, $builder->{$get}(), 'Getter gets value.');
  131. }
  132. /**
  133. * Test array property accessor/mutator methods.
  134. *
  135. * @dataProvider arrayPropertyProvider
  136. * @return void
  137. */
  138. public function testArrayProperties($property, $value)
  139. {
  140. $get = 'get' . ucfirst($property);
  141. $set = 'set' . ucfirst($property);
  142. $builder = new ViewBuilder();
  143. $this->assertSame([], $builder->{$get}(), 'Default value should be empty list');
  144. $this->assertSame($builder, $builder->{$set}($value), 'Setter returns this');
  145. $this->assertSame($value, $builder->{$get}(), 'Getter gets value.');
  146. }
  147. /**
  148. * Test array property accessor/mutator methods.
  149. *
  150. * @dataProvider arrayPropertyProvider
  151. * @return void
  152. */
  153. public function testArrayPropertyMerge($property, $value)
  154. {
  155. $get = 'get' . ucfirst($property);
  156. $set = 'set' . ucfirst($property);
  157. $builder = new ViewBuilder();
  158. $builder->{$set}($value);
  159. $builder->{$set}(['Merged'], true);
  160. $this->assertSame(array_merge($value, ['Merged']), $builder->{$get}(), 'Should merge');
  161. $builder->{$set}($value, false);
  162. $this->assertSame($value, $builder->{$get}(), 'Should replace');
  163. }
  164. /**
  165. * test building with all the options.
  166. *
  167. * @return void
  168. */
  169. public function testBuildComplete()
  170. {
  171. $request = new ServerRequest();
  172. $response = new Response();
  173. $events = $this->getMockBuilder('Cake\Event\EventManager')->getMock();
  174. $builder = new ViewBuilder();
  175. $builder->setName('Articles')
  176. ->setClassName('Ajax')
  177. ->setTemplate('edit')
  178. ->setLayout('default')
  179. ->setTemplatePath('Articles/')
  180. ->setHelpers(['Form', 'Html'])
  181. ->setLayoutPath('Admin/')
  182. ->setTheme('TestTheme')
  183. ->setPlugin('TestPlugin')
  184. ->setVars(['foo' => 'bar', 'x' => 'old']);
  185. $view = $builder->build(
  186. ['one' => 'value', 'x' => 'new'],
  187. $request,
  188. $response,
  189. $events
  190. );
  191. $this->assertInstanceOf('Cake\View\AjaxView', $view);
  192. $this->assertEquals('edit', $view->getTemplate());
  193. $this->assertEquals('default', $view->getLayout());
  194. $this->assertEquals('Articles/', $view->getTemplatePath());
  195. $this->assertEquals('Admin/', $view->getLayoutPath());
  196. $this->assertEquals('TestPlugin', $view->getPlugin());
  197. $this->assertEquals('TestTheme', $view->getTheme());
  198. $this->assertSame($request, $view->getRequest());
  199. $this->assertInstanceOf(Response::class, $view->getResponse());
  200. $this->assertSame($events, $view->getEventManager());
  201. $this->assertSame(['one', 'x', 'foo'], $view->getVars());
  202. $this->assertSame('value', $view->get('one'));
  203. $this->assertSame('bar', $view->get('foo'));
  204. $this->assertInstanceOf('Cake\View\Helper\HtmlHelper', $view->Html);
  205. $this->assertInstanceOf('Cake\View\Helper\FormHelper', $view->Form);
  206. }
  207. /**
  208. * Test that the default is AppView.
  209. *
  210. * @return void
  211. */
  212. public function testBuildAppViewMissing()
  213. {
  214. static::setAppNamespace('Nope');
  215. $builder = new ViewBuilder();
  216. $view = $builder->build();
  217. $this->assertInstanceOf('Cake\View\View', $view);
  218. }
  219. /**
  220. * Test that the default is AppView.
  221. *
  222. * @return void
  223. */
  224. public function testBuildAppViewPresent()
  225. {
  226. static::setAppNamespace();
  227. $builder = new ViewBuilder();
  228. $view = $builder->build();
  229. $this->assertInstanceOf('TestApp\View\AppView', $view);
  230. }
  231. /**
  232. * test missing view class
  233. *
  234. * @return void
  235. */
  236. public function testBuildMissingViewClass()
  237. {
  238. $this->expectException(\Cake\View\Exception\MissingViewException::class);
  239. $this->expectExceptionMessage('View class "Foo" is missing.');
  240. $builder = new ViewBuilder();
  241. $builder->setClassName('Foo');
  242. $builder->build();
  243. }
  244. /**
  245. * testJsonSerialize()
  246. *
  247. * @return void
  248. */
  249. public function testJsonSerialize()
  250. {
  251. $builder = new ViewBuilder();
  252. $builder
  253. ->setTemplate('default')
  254. ->setLayout('test')
  255. ->setHelpers(['Html'])
  256. ->setClassName('JsonView');
  257. $result = json_decode(json_encode($builder), true);
  258. $expected = [
  259. '_template' => 'default',
  260. '_layout' => 'test',
  261. '_helpers' => ['Html'],
  262. '_className' => 'JsonView',
  263. '_autoLayout' => true,
  264. ];
  265. $this->assertEquals($expected, $result);
  266. $result = json_decode(json_encode(unserialize(serialize($builder))), true);
  267. $this->assertEquals($expected, $result);
  268. }
  269. /**
  270. * testCreateFromArray()
  271. *
  272. * @return void
  273. */
  274. public function testCreateFromArray()
  275. {
  276. $builder = new ViewBuilder();
  277. $builder
  278. ->setTemplate('default')
  279. ->setLayout('test')
  280. ->setHelpers(['Html'])
  281. ->setClassName('JsonView');
  282. $result = json_encode($builder);
  283. $builder = new ViewBuilder();
  284. $builder->createFromArray(json_decode($result, true));
  285. $this->assertEquals('default', $builder->getTemplate());
  286. $this->assertEquals('test', $builder->getLayout());
  287. $this->assertEquals(['Html'], $builder->getHelpers());
  288. $this->assertEquals('JsonView', $builder->getClassName());
  289. }
  290. /**
  291. * test setOptions() with 1 string param, merge true
  292. *
  293. * @return void
  294. */
  295. public function testSetOptionsOne()
  296. {
  297. $builder = new ViewBuilder();
  298. $this->assertSame($builder, $builder->setOptions(['newOption']));
  299. $this->assertContains('newOption', $builder->getOptions());
  300. }
  301. /**
  302. * test setOptions() with 2 strings in array, merge true.
  303. *
  304. * @return void
  305. */
  306. public function testSetOptionsMultiple()
  307. {
  308. $builder = new ViewBuilder();
  309. $builder->setOptions(['oldOption'], false);
  310. $option = ['newOption', 'anotherOption'];
  311. $builder->setOptions($option);
  312. $expects = ['oldOption', 'newOption', 'anotherOption'];
  313. $result = $builder->getOptions();
  314. $this->assertContainsOnly('string', $result);
  315. $this->assertEquals($expects, $result);
  316. }
  317. /**
  318. * test empty params reads _viewOptions.
  319. *
  320. * @return void
  321. */
  322. public function testReadingViewOptions()
  323. {
  324. $builder = new ViewBuilder();
  325. $builder->setOptions(['one', 'two', 'three'], false);
  326. $this->assertEquals(['one', 'two', 'three'], $builder->getOptions());
  327. }
  328. /**
  329. * test setting $merge `false` overrides correct options.
  330. *
  331. * @return void
  332. */
  333. public function testMergeFalseViewOptions()
  334. {
  335. $builder = new ViewBuilder();
  336. $builder->setOptions(['one', 'two', 'three'], false);
  337. $expected = ['four', 'five', 'six'];
  338. $builder->setOptions($expected, false);
  339. $this->assertEquals($expected, $builder->getOptions());
  340. }
  341. /**
  342. * test _viewOptions is undefined and $opts is null, an empty array is returned.
  343. *
  344. * @return void
  345. */
  346. public function testUndefinedValidViewOptions()
  347. {
  348. $builder = new ViewBuilder();
  349. $builder->setOptions([], false);
  350. $result = $builder->getOptions();
  351. $this->assertInternalType('array', $result);
  352. $this->assertEmpty($result);
  353. }
  354. /**
  355. * testDisableAutoLayout
  356. *
  357. * @return void
  358. */
  359. public function testDisableAutoLayout()
  360. {
  361. $builder = new ViewBuilder();
  362. $this->assertTrue($builder->isAutoLayoutEnabled());
  363. $builder->disableAutoLayout();
  364. $this->assertFalse($builder->isAutoLayoutEnabled());
  365. }
  366. }