JsonViewTest.php 11 KB

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