JsonViewTest.php 8.1 KB

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