XmlViewTest.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * XmlViewTest file
  5. *
  6. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  7. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  8. *
  9. * Licensed under The MIT License
  10. * For full copyright and license information, please see the LICENSE.txt
  11. * Redistributions of files must retain the above copyright notice
  12. *
  13. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  14. * @link https://cakephp.org CakePHP(tm) Project
  15. * @since 2.1.0
  16. * @license https://opensource.org/licenses/mit-license.php MIT License
  17. */
  18. namespace Cake\Test\TestCase\View;
  19. use Cake\Controller\Controller;
  20. use Cake\Core\Configure;
  21. use Cake\Http\Response;
  22. use Cake\Http\ServerRequest;
  23. use Cake\TestSuite\TestCase;
  24. use Cake\Utility\Xml;
  25. /**
  26. * XmlViewTest
  27. */
  28. class XmlViewTest extends TestCase
  29. {
  30. protected $fixtures = ['core.Authors'];
  31. public function setUp(): void
  32. {
  33. parent::setUp();
  34. Configure::write('debug', false);
  35. }
  36. /**
  37. * testRenderWithoutView method
  38. *
  39. * @return void
  40. */
  41. public function testRenderWithoutView()
  42. {
  43. $Request = new ServerRequest();
  44. $Response = new Response();
  45. $Controller = new Controller($Request, $Response);
  46. $data = ['users' => ['user' => ['user1', 'user2']]];
  47. $Controller->set(['users' => $data]);
  48. $Controller->viewBuilder()
  49. ->setClassName('Xml')
  50. ->setOption('serialize', 'users');
  51. $View = $Controller->createView();
  52. $output = $View->render();
  53. $this->assertSame(Xml::build($data)->asXML(), $output);
  54. $this->assertSame('application/xml', $View->getResponse()->getType());
  55. $data = [
  56. [
  57. 'User' => [
  58. 'username' => 'user1',
  59. ],
  60. ],
  61. [
  62. 'User' => [
  63. 'username' => 'user2',
  64. ],
  65. ],
  66. ];
  67. $Controller->set(['users' => $data]);
  68. $Controller->viewBuilder()
  69. ->setClassName('Xml')
  70. ->setOption('serialize', 'users');
  71. $View = $Controller->createView();
  72. $output = $View->render();
  73. $expected = Xml::build(['response' => ['users' => $data]])->asXML();
  74. $this->assertSame($expected, $output);
  75. $Controller->viewBuilder()
  76. ->setClassName('Xml')
  77. ->setOption('rootNode', 'custom_name');
  78. $View = $Controller->createView();
  79. $output = $View->render();
  80. $expected = Xml::build(['custom_name' => ['users' => $data]])->asXML();
  81. $this->assertSame($expected, $output);
  82. }
  83. /**
  84. * Test that rendering with _serialize does not load helpers
  85. *
  86. * @return void
  87. */
  88. public function testRenderSerializeNoHelpers()
  89. {
  90. $Request = new ServerRequest();
  91. $Response = new Response();
  92. $Controller = new Controller($Request, $Response);
  93. $Controller->set([
  94. 'tags' => ['cakephp', 'framework'],
  95. ]);
  96. $Controller->viewBuilder()
  97. ->setClassName('Xml')
  98. ->setOption('serialize', 'tags');
  99. $View = $Controller->createView();
  100. $View->render();
  101. $this->assertFalse(isset($View->Html), 'No helper loaded.');
  102. }
  103. /**
  104. * Test that rendering with _serialize respects XML options.
  105. *
  106. * @return void
  107. */
  108. public function testRenderSerializeWithOptions()
  109. {
  110. $Request = new ServerRequest();
  111. $Response = new Response();
  112. $Controller = new Controller($Request, $Response);
  113. $data = [
  114. 'tags' => [
  115. 'tag' => [
  116. [
  117. 'id' => '1',
  118. 'name' => 'defect',
  119. ],
  120. [
  121. 'id' => '2',
  122. 'name' => 'enhancement',
  123. ],
  124. ],
  125. ],
  126. ];
  127. $xmlOptions = ['format' => ['format' => 'attributes', 'return' => 'domdocument']];
  128. $Controller->set($data);
  129. $Controller->viewBuilder()
  130. ->setClassName('Xml')
  131. ->setOption('serialize', ['tags', 'nope'])
  132. ->setOption('xmlOptions', $xmlOptions);
  133. $View = $Controller->createView();
  134. $result = $View->render();
  135. $expected = Xml::build(['response' => ['tags' => $data['tags']]], $xmlOptions)->saveXML();
  136. $this->assertSame($expected, $result);
  137. }
  138. /**
  139. * Test that rendering with _serialize can work with string setting.
  140. *
  141. * @return void
  142. */
  143. public function testRenderSerializeWithString()
  144. {
  145. $Request = new ServerRequest();
  146. $Response = new Response();
  147. $Controller = new Controller($Request, $Response);
  148. $data = [
  149. 'tags' => [
  150. 'tags' => [
  151. 'tag' => [
  152. [
  153. 'id' => '1',
  154. 'name' => 'defect',
  155. ],
  156. [
  157. 'id' => '2',
  158. 'name' => 'enhancement',
  159. ],
  160. ],
  161. ],
  162. ],
  163. ];
  164. $xmlOptions = ['format' => 'attributes'];
  165. $Controller->set($data);
  166. $Controller->viewBuilder()
  167. ->setClassName('Xml')
  168. ->setOption('serialize', 'tags')
  169. ->setOption('xmlOptions', $xmlOptions);
  170. $View = $Controller->createView();
  171. $result = $View->render();
  172. $expected = Xml::build($data['tags'], $xmlOptions)->asXML();
  173. $this->assertSame($expected, $result);
  174. }
  175. /**
  176. * Test render with an array in _serialize
  177. *
  178. * @return void
  179. */
  180. public function testRenderWithoutViewMultiple()
  181. {
  182. $Request = new ServerRequest();
  183. $Response = new Response();
  184. $Controller = new Controller($Request, $Response);
  185. $data = ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']];
  186. $Controller->set($data);
  187. $Controller->viewBuilder()
  188. ->setClassName('Xml')
  189. ->setOption('serialize', ['no', 'user']);
  190. $View = $Controller->createView();
  191. $this->assertSame('application/xml', $View->getResponse()->getType());
  192. $output = $View->render();
  193. $expected = [
  194. 'response' => ['no' => $data['no'], 'user' => $data['user']],
  195. ];
  196. $this->assertSame(Xml::build($expected)->asXML(), $output);
  197. $Controller->viewBuilder()
  198. ->setClassName('Xml')
  199. ->setOption('rootNode', 'custom_name');
  200. $View = $Controller->createView();
  201. $output = $View->render();
  202. $expected = [
  203. 'custom_name' => ['no' => $data['no'], 'user' => $data['user']],
  204. ];
  205. $this->assertSame(Xml::build($expected)->asXML(), $output);
  206. }
  207. /**
  208. * Test render with an array in _serialize and alias
  209. *
  210. * @return void
  211. */
  212. public function testRenderWithoutViewMultipleAndAlias()
  213. {
  214. $Request = new ServerRequest();
  215. $Response = new Response();
  216. $Controller = new Controller($Request, $Response);
  217. $data = ['original_name' => 'my epic name', 'user' => 'fake', 'list' => ['item1', 'item2']];
  218. $Controller->set($data);
  219. $Controller->viewBuilder()
  220. ->setClassName('Xml')
  221. ->setOption('serialize', ['new_name' => 'original_name', 'user']);
  222. $View = $Controller->createView();
  223. $this->assertSame('application/xml', $View->getResponse()->getType());
  224. $output = $View->render();
  225. $expected = [
  226. 'response' => ['new_name' => $data['original_name'], 'user' => $data['user']],
  227. ];
  228. $this->assertSame(Xml::build($expected)->asXML(), $output);
  229. $Controller->viewBuilder()
  230. ->setClassName('Xml')
  231. ->setOption('rootNode', 'custom_name');
  232. $View = $Controller->createView();
  233. $output = $View->render();
  234. $expected = [
  235. 'custom_name' => ['new_name' => $data['original_name'], 'user' => $data['user']],
  236. ];
  237. $this->assertSame(Xml::build($expected)->asXML(), $output);
  238. }
  239. /**
  240. * test rendering with _serialize true
  241. *
  242. * @return void
  243. */
  244. public function testRenderWithSerializeTrue()
  245. {
  246. $Request = new ServerRequest();
  247. $Response = new Response();
  248. $Controller = new Controller($Request, $Response);
  249. $data = ['users' => ['user' => ['user1', 'user2']]];
  250. $Controller->set(['users' => $data]);
  251. $Controller->viewBuilder()
  252. ->setClassName('Xml')
  253. ->setOption('serialize', true);
  254. $View = $Controller->createView();
  255. $output = $View->render();
  256. $this->assertSame(Xml::build($data)->asXML(), $output);
  257. $this->assertSame('application/xml', $View->getResponse()->getType());
  258. $data = ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']];
  259. $Controller = new Controller($Request, $Response);
  260. $Controller->viewBuilder()
  261. ->setClassName('Xml')
  262. ->setOption('serialize', true);
  263. $Controller->set($data);
  264. $View = $Controller->createView();
  265. $output = $View->render();
  266. $expected = [
  267. 'response' => $data,
  268. ];
  269. $this->assertSame(Xml::build($expected)->asXML(), $output);
  270. }
  271. /**
  272. * testRenderWithView method
  273. *
  274. * @return void
  275. */
  276. public function testRenderWithView()
  277. {
  278. $Request = new ServerRequest();
  279. $Response = new Response();
  280. $Controller = new Controller($Request, $Response);
  281. $Controller->setName('Posts');
  282. $data = [
  283. [
  284. 'User' => [
  285. 'username' => 'user1',
  286. ],
  287. ],
  288. [
  289. 'User' => [
  290. 'username' => 'user2',
  291. ],
  292. ],
  293. ];
  294. $Controller->set('users', $data);
  295. $Controller->viewBuilder()->setClassName('Xml');
  296. $View = $Controller->createView();
  297. $View->setTemplatePath('Posts');
  298. $output = $View->render('index');
  299. $expected = [
  300. 'users' => ['user' => ['user1', 'user2']],
  301. ];
  302. $expected = Xml::build($expected)->asXML();
  303. $this->assertSame($expected, $output);
  304. $this->assertSame('application/xml', $View->getResponse()->getType());
  305. $this->assertInstanceOf('Cake\View\HelperRegistry', $View->helpers());
  306. }
  307. public function testSerializingResultSet()
  308. {
  309. $Request = new ServerRequest();
  310. $Response = new Response();
  311. $Controller = new Controller($Request, $Response);
  312. $data = $this->getTableLocator()->get('Authors')
  313. ->find('all')
  314. ->where(['id' => 1]);
  315. $Controller->set(['authors' => $data]);
  316. $Controller->viewBuilder()
  317. ->setClassName('Xml')
  318. ->setOption('serialize', true);
  319. $View = $Controller->createView();
  320. $output = $View->render();
  321. $this->assertSame(
  322. '<?xml version="1.0" encoding="UTF-8"?>' . "\n"
  323. . '<response><authors><id>1</id><name>mariano</name></authors></response>' . "\n",
  324. $output
  325. );
  326. $this->assertSame('application/xml', $View->getResponse()->getType());
  327. }
  328. }