XmlViewTest.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. <?php
  2. /**
  3. * XmlViewTest file
  4. *
  5. * CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
  6. * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  7. *
  8. * Licensed under The MIT License
  9. * For full copyright and license information, please see the LICENSE.txt
  10. * Redistributions of files must retain the above copyright notice
  11. *
  12. * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  13. * @link http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
  14. * @since 2.1.0
  15. * @license http://www.opensource.org/licenses/mit-license.php MIT License
  16. */
  17. namespace Cake\Test\TestCase\View;
  18. use Cake\Controller\Controller;
  19. use Cake\Core\App;
  20. use Cake\Core\Configure;
  21. use Cake\Network\Request;
  22. use Cake\Network\Response;
  23. use Cake\TestSuite\TestCase;
  24. use Cake\Utility\Xml;
  25. use Cake\View\XmlView;
  26. /**
  27. * XmlViewTest
  28. *
  29. */
  30. class XmlViewTest extends TestCase
  31. {
  32. public function setUp()
  33. {
  34. parent::setUp();
  35. Configure::write('debug', false);
  36. }
  37. /**
  38. * testRenderWithoutView method
  39. *
  40. * @return void
  41. */
  42. public function testRenderWithoutView()
  43. {
  44. $Request = new Request();
  45. $Response = new Response();
  46. $Controller = new Controller($Request, $Response);
  47. $data = ['users' => ['user' => ['user1', 'user2']]];
  48. $Controller->set(['users' => $data, '_serialize' => 'users']);
  49. $Controller->viewClass = 'Xml';
  50. $View = $Controller->createView();
  51. $output = $View->render(false);
  52. $this->assertSame(Xml::build($data)->asXML(), $output);
  53. $this->assertSame('application/xml', $Response->type());
  54. $data = [
  55. [
  56. 'User' => [
  57. 'username' => 'user1'
  58. ]
  59. ],
  60. [
  61. 'User' => [
  62. 'username' => 'user2'
  63. ]
  64. ]
  65. ];
  66. $Controller->set(['users' => $data, '_serialize' => 'users']);
  67. $Controller->viewClass = 'Xml';
  68. $View = $Controller->createView();
  69. $output = $View->render(false);
  70. $expected = Xml::build(['response' => ['users' => $data]])->asXML();
  71. $this->assertSame($expected, $output);
  72. $Controller->set('_rootNode', 'custom_name');
  73. $Controller->viewClass = 'Xml';
  74. $View = $Controller->createView();
  75. $output = $View->render(false);
  76. $expected = Xml::build(['custom_name' => ['users' => $data]])->asXML();
  77. $this->assertSame($expected, $output);
  78. }
  79. /**
  80. * Test that rendering with _serialize does not load helpers
  81. *
  82. * @return void
  83. */
  84. public function testRenderSerializeNoHelpers()
  85. {
  86. $Request = new Request();
  87. $Response = new Response();
  88. $Controller = new Controller($Request, $Response);
  89. $Controller->helpers = ['Html'];
  90. $Controller->set([
  91. '_serialize' => 'tags',
  92. 'tags' => ['cakephp', 'framework']
  93. ]);
  94. $Controller->viewClass = 'Xml';
  95. $View = $Controller->createView();
  96. $View->render();
  97. $this->assertFalse(isset($View->Html), 'No helper loaded.');
  98. }
  99. /**
  100. * Test that rendering with _serialize respects XML options.
  101. *
  102. * @return void
  103. */
  104. public function testRenderSerializeWithOptions()
  105. {
  106. $Request = new Request();
  107. $Response = new Response();
  108. $Controller = new Controller($Request, $Response);
  109. $data = [
  110. '_serialize' => ['tags'],
  111. '_xmlOptions' => ['format' => 'attributes'],
  112. 'tags' => [
  113. 'tag' => [
  114. [
  115. 'id' => '1',
  116. 'name' => 'defect'
  117. ],
  118. [
  119. 'id' => '2',
  120. 'name' => 'enhancement'
  121. ]
  122. ]
  123. ]
  124. ];
  125. $Controller->set($data);
  126. $Controller->viewClass = 'Xml';
  127. $View = $Controller->createView();
  128. $result = $View->render();
  129. $expected = Xml::build(['response' => ['tags' => $data['tags']]], $data['_xmlOptions'])->asXML();
  130. $this->assertSame($expected, $result);
  131. }
  132. /**
  133. * Test that rendering with _serialize can work with string setting.
  134. *
  135. * @return void
  136. */
  137. public function testRenderSerializeWithString()
  138. {
  139. $Request = new Request();
  140. $Response = new Response();
  141. $Controller = new Controller($Request, $Response);
  142. $data = [
  143. '_serialize' => 'tags',
  144. '_xmlOptions' => ['format' => 'attributes'],
  145. 'tags' => [
  146. 'tags' => [
  147. 'tag' => [
  148. [
  149. 'id' => '1',
  150. 'name' => 'defect'
  151. ],
  152. [
  153. 'id' => '2',
  154. 'name' => 'enhancement'
  155. ]
  156. ]
  157. ]
  158. ]
  159. ];
  160. $Controller->set($data);
  161. $Controller->viewClass = 'Xml';
  162. $View = $Controller->createView();
  163. $result = $View->render();
  164. $expected = Xml::build($data['tags'], $data['_xmlOptions'])->asXML();
  165. $this->assertSame($expected, $result);
  166. }
  167. /**
  168. * Test render with an array in _serialize
  169. *
  170. * @return void
  171. */
  172. public function testRenderWithoutViewMultiple()
  173. {
  174. $Request = new Request();
  175. $Response = new Response();
  176. $Controller = new Controller($Request, $Response);
  177. $data = ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']];
  178. $Controller->set($data);
  179. $Controller->set('_serialize', ['no', 'user']);
  180. $Controller->viewClass = 'Xml';
  181. $View = $Controller->createView();
  182. $this->assertSame('application/xml', $Response->type());
  183. $output = $View->render(false);
  184. $expected = [
  185. 'response' => ['no' => $data['no'], 'user' => $data['user']]
  186. ];
  187. $this->assertSame(Xml::build($expected)->asXML(), $output);
  188. $Controller->set('_rootNode', 'custom_name');
  189. $Controller->viewClass = 'Xml';
  190. $View = $Controller->createView();
  191. $output = $View->render(false);
  192. $expected = [
  193. 'custom_name' => ['no' => $data['no'], 'user' => $data['user']]
  194. ];
  195. $this->assertSame(Xml::build($expected)->asXML(), $output);
  196. }
  197. /**
  198. * Test render with an array in _serialize and alias
  199. *
  200. * @return void
  201. */
  202. public function testRenderWithoutViewMultipleAndAlias()
  203. {
  204. $Request = new Request();
  205. $Response = new Response();
  206. $Controller = new Controller($Request, $Response);
  207. $data = ['original_name' => 'my epic name', 'user' => 'fake', 'list' => ['item1', 'item2']];
  208. $Controller->set($data);
  209. $Controller->set('_serialize', ['new_name' => 'original_name', 'user']);
  210. $Controller->viewClass = 'Xml';
  211. $View = $Controller->createView();
  212. $this->assertSame('application/xml', $Response->type());
  213. $output = $View->render(false);
  214. $expected = [
  215. 'response' => ['new_name' => $data['original_name'], 'user' => $data['user']]
  216. ];
  217. $this->assertSame(Xml::build($expected)->asXML(), $output);
  218. $Controller->set('_rootNode', 'custom_name');
  219. $Controller->viewClass = 'Xml';
  220. $View = $Controller->createView();
  221. $output = $View->render(false);
  222. $expected = [
  223. 'custom_name' => ['new_name' => $data['original_name'], 'user' => $data['user']]
  224. ];
  225. $this->assertSame(Xml::build($expected)->asXML(), $output);
  226. }
  227. /**
  228. * testRenderWithView method
  229. *
  230. * @return void
  231. */
  232. public function testRenderWithView()
  233. {
  234. $Request = new Request();
  235. $Response = new Response();
  236. $Controller = new Controller($Request, $Response);
  237. $Controller->name = 'Posts';
  238. $Controller->viewPath = 'Posts';
  239. $data = [
  240. [
  241. 'User' => [
  242. 'username' => 'user1'
  243. ]
  244. ],
  245. [
  246. 'User' => [
  247. 'username' => 'user2'
  248. ]
  249. ]
  250. ];
  251. $Controller->set('users', $data);
  252. $Controller->viewClass = 'Xml';
  253. $View = $Controller->createView();
  254. $output = $View->render('index');
  255. $expected = [
  256. 'users' => ['user' => ['user1', 'user2']]
  257. ];
  258. $expected = Xml::build($expected)->asXML();
  259. $this->assertSame($expected, $output);
  260. $this->assertSame('application/xml', $Response->type());
  261. $this->assertInstanceOf('Cake\View\HelperRegistry', $View->helpers());
  262. }
  263. }