JsonViewTest.php 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323
  1. <?php
  2. /**
  3. * JsonViewTest file
  4. *
  5. * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
  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://cakephp.org CakePHP(tm) Project
  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\Configure;
  20. use Cake\Network\Request;
  21. use Cake\Network\Response;
  22. use Cake\TestSuite\TestCase;
  23. /**
  24. * JsonViewTest
  25. *
  26. */
  27. class JsonViewTest extends TestCase
  28. {
  29. public function setUp()
  30. {
  31. parent::setUp();
  32. Configure::write('debug', false);
  33. }
  34. /**
  35. * Generates testRenderWithoutView data.
  36. *
  37. * Note: array($data, $serialize, expected)
  38. *
  39. * @return void
  40. */
  41. public static function renderWithoutViewProvider()
  42. {
  43. return [
  44. // Test render with a valid string in _serialize.
  45. [
  46. ['data' => ['user' => 'fake', 'list' => ['item1', 'item2']]],
  47. 'data',
  48. null,
  49. json_encode(['user' => 'fake', 'list' => ['item1', 'item2']])
  50. ],
  51. // Test render with a string with an invalid key in _serialize.
  52. [
  53. ['data' => ['user' => 'fake', 'list' => ['item1', 'item2']]],
  54. 'no_key',
  55. null,
  56. json_encode(null)
  57. ],
  58. // Test render with a valid array in _serialize.
  59. [
  60. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  61. ['no', 'user'],
  62. null,
  63. json_encode(['no' => 'nope', 'user' => 'fake'])
  64. ],
  65. // Test render with an empty array in _serialize.
  66. [
  67. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  68. [],
  69. null,
  70. json_encode(null)
  71. ],
  72. // Test render with a valid array with an invalid key in _serialize.
  73. [
  74. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  75. ['no', 'user', 'no_key'],
  76. null,
  77. json_encode(['no' => 'nope', 'user' => 'fake'])
  78. ],
  79. // Test render with a valid array with only an invalid key in _serialize.
  80. [
  81. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  82. ['no_key'],
  83. null,
  84. json_encode(null)
  85. ],
  86. // Test render with Null in _serialize (unset).
  87. [
  88. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  89. null,
  90. null,
  91. null
  92. ],
  93. // Test render with False in _serialize.
  94. [
  95. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  96. false,
  97. null,
  98. null
  99. ],
  100. // Test render with True in _serialize.
  101. [
  102. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  103. true,
  104. JSON_HEX_QUOT,
  105. json_encode(['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']])
  106. ],
  107. // Test render with True in _serialize and single var
  108. [
  109. ['no' => 'nope'],
  110. true,
  111. null,
  112. json_encode(['no' => 'nope'])
  113. ],
  114. // Test render with empty string in _serialize.
  115. [
  116. ['no' => 'nope', 'user' => 'fake', 'list' => ['item1', 'item2']],
  117. '',
  118. null,
  119. json_encode(null)
  120. ],
  121. // Test render with a valid array in _serialize and alias.
  122. [
  123. ['original_name' => 'my epic name', 'user' => 'fake', 'list' => ['item1', 'item2']],
  124. ['new_name' => 'original_name', 'user'],
  125. null,
  126. json_encode(['new_name' => 'my epic name', 'user' => 'fake'])
  127. ],
  128. // Test render with an a valid array in _serialize and alias of a null value.
  129. [
  130. ['null' => null],
  131. ['null'],
  132. null,
  133. json_encode(['null' => null])
  134. ],
  135. // Test render with a False value to be serialized.
  136. [
  137. ['false' => false],
  138. 'false',
  139. null,
  140. json_encode(false)
  141. ],
  142. // Test render with a True value to be serialized.
  143. [
  144. ['true' => true],
  145. 'true',
  146. null,
  147. json_encode(true)
  148. ],
  149. // Test render with an empty string value to be serialized.
  150. [
  151. ['empty' => ''],
  152. 'empty',
  153. null,
  154. json_encode('')
  155. ],
  156. // Test render with a zero value to be serialized.
  157. [
  158. ['zero' => 0],
  159. 'zero',
  160. null,
  161. json_encode(0)
  162. ],
  163. // Test render with encode <, >, ', &, and " for RFC4627-compliant to be serialized.
  164. [
  165. ['rfc4627_escape' => '<tag> \'quote\' "double-quote" &'],
  166. 'rfc4627_escape',
  167. null,
  168. json_encode('<tag> \'quote\' "double-quote" &', JSON_HEX_TAG | JSON_HEX_APOS | JSON_HEX_AMP | JSON_HEX_QUOT)
  169. ],
  170. // Test render with _jsonOptions = false to be serialized.
  171. [
  172. ['noescape' => '<tag> \'quote\' "double-quote" &'],
  173. 'noescape',
  174. false,
  175. json_encode('<tag> \'quote\' "double-quote" &')
  176. ],
  177. // Test render with setting _jsonOptions to be serialized.
  178. [
  179. ['rfc4627_escape' => '<tag> \'quote\' "double-quote" &'],
  180. 'rfc4627_escape',
  181. JSON_HEX_TAG | JSON_HEX_APOS,
  182. json_encode('<tag> \'quote\' "double-quote" &', JSON_HEX_TAG | JSON_HEX_APOS)
  183. ],
  184. ];
  185. }
  186. /**
  187. * Test render with a valid string in _serialize.
  188. *
  189. * @dataProvider renderWithoutViewProvider
  190. * @return void
  191. */
  192. public function testRenderWithoutView($data, $serialize, $jsonOptions, $expected)
  193. {
  194. $Request = new Request();
  195. $Response = new Response();
  196. $Controller = new Controller($Request, $Response);
  197. $Controller->set($data);
  198. $Controller->set('_serialize', $serialize);
  199. $Controller->set('_jsonOptions', $jsonOptions);
  200. $Controller->viewClass = 'Json';
  201. $View = $Controller->createView();
  202. $output = $View->render(false);
  203. $this->assertSame($expected, $output);
  204. }
  205. /**
  206. * Test that rendering with _serialize does not load helpers.
  207. *
  208. * @return void
  209. */
  210. public function testRenderSerializeNoHelpers()
  211. {
  212. $Request = new Request();
  213. $Response = new Response();
  214. $Controller = new Controller($Request, $Response);
  215. $Controller->helpers = ['Html'];
  216. $Controller->set([
  217. 'tags' => ['cakephp', 'framework'],
  218. '_serialize' => 'tags'
  219. ]);
  220. $Controller->viewClass = 'Json';
  221. $View = $Controller->createView();
  222. $View->render();
  223. $this->assertFalse(isset($View->Html), 'No helper loaded.');
  224. }
  225. /**
  226. * testJsonpResponse method
  227. *
  228. * @return void
  229. */
  230. public function testJsonpResponse()
  231. {
  232. $Request = new Request();
  233. $Response = new Response();
  234. $Controller = new Controller($Request, $Response);
  235. $data = ['user' => 'fake', 'list' => ['item1', 'item2']];
  236. $Controller->set([
  237. 'data' => $data,
  238. '_serialize' => 'data',
  239. '_jsonp' => true
  240. ]);
  241. $Controller->viewClass = 'Json';
  242. $View = $Controller->createView();
  243. $output = $View->render(false);
  244. $this->assertSame(json_encode($data), $output);
  245. $this->assertSame('application/json', $Response->type());
  246. $View->request->query = ['callback' => 'jfunc'];
  247. $output = $View->render(false);
  248. $expected = 'jfunc(' . json_encode($data) . ')';
  249. $this->assertSame($expected, $output);
  250. $this->assertSame('application/javascript', $Response->type());
  251. $View->request->query = ['jsonCallback' => 'jfunc'];
  252. $View->viewVars['_jsonp'] = 'jsonCallback';
  253. $output = $View->render(false);
  254. $expected = 'jfunc(' . json_encode($data) . ')';
  255. $this->assertSame($expected, $output);
  256. }
  257. /**
  258. * Test render with a View file specified.
  259. *
  260. * @return void
  261. */
  262. public function testRenderWithView()
  263. {
  264. $Request = new Request();
  265. $Response = new Response();
  266. $Controller = new Controller($Request, $Response);
  267. $Controller->name = 'Posts';
  268. $data = [
  269. 'User' => [
  270. 'username' => 'fake'
  271. ],
  272. 'Item' => [
  273. ['name' => 'item1'],
  274. ['name' => 'item2']
  275. ]
  276. ];
  277. $Controller->set('user', $data);
  278. $Controller->viewClass = 'Json';
  279. $View = $Controller->createView();
  280. $View->viewPath = $Controller->name;
  281. $output = $View->render('index');
  282. $expected = json_encode(['user' => 'fake', 'list' => ['item1', 'item2'], 'paging' => null]);
  283. $this->assertSame($expected, $output);
  284. $this->assertSame('application/json', $Response->type());
  285. }
  286. }