FlashMessageTest.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  5. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  6. *
  7. * Licensed under The MIT License
  8. * For full copyright and license information, please see the LICENSE.txt
  9. * Redistributions of files must retain the above copyright notice
  10. *
  11. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  12. * @link https://cakephp.org CakePHP(tm) Project
  13. * @since 4.2.0
  14. * @license https://opensource.org/licenses/mit-license.php MIT License
  15. */
  16. namespace Cake\Test\TestCase\Http;
  17. use Cake\Http\FlashMessage;
  18. use Cake\Http\Session;
  19. use Cake\TestSuite\TestCase;
  20. use Exception;
  21. /**
  22. * FlashMessageTest class
  23. */
  24. class FlashMessageTest extends TestCase
  25. {
  26. /**
  27. * @var \Cake\Http\FlashMessage
  28. */
  29. protected $Flash;
  30. /**
  31. * @var \Cake\Http\Session
  32. */
  33. protected $Session;
  34. public function setUp(): void
  35. {
  36. parent::setUp();
  37. static::setAppNamespace();
  38. $this->Session = new Session();
  39. $this->Flash = new FlashMessage($this->Session);
  40. }
  41. public function tearDown(): void
  42. {
  43. parent::tearDown();
  44. $this->Session->destroy();
  45. }
  46. public function testSet(): void
  47. {
  48. $this->assertNull($this->Session->read('Flash.flash'));
  49. $this->Flash->set('This is a test message');
  50. $expected = [
  51. [
  52. 'message' => 'This is a test message',
  53. 'key' => 'flash',
  54. 'element' => 'flash/default',
  55. 'params' => [],
  56. ],
  57. ];
  58. $result = $this->Session->read('Flash.flash');
  59. $this->assertEquals($expected, $result);
  60. $this->Flash->set(
  61. 'This is a test message',
  62. ['element' => 'test', 'params' => ['foo' => 'bar']]
  63. );
  64. $expected[] = [
  65. 'message' => 'This is a test message',
  66. 'key' => 'flash',
  67. 'element' => 'flash/test',
  68. 'params' => ['foo' => 'bar'],
  69. ];
  70. $result = $this->Session->read('Flash.flash');
  71. $this->assertEquals($expected, $result);
  72. $this->Flash->set('This is a test message', ['element' => 'MyPlugin.alert']);
  73. $expected[] = [
  74. 'message' => 'This is a test message',
  75. 'key' => 'flash',
  76. 'element' => 'MyPlugin.flash/alert',
  77. 'params' => [],
  78. ];
  79. $result = $this->Session->read('Flash.flash');
  80. $this->assertEquals($expected, $result);
  81. $this->Flash->set('This is a test message', ['key' => 'foobar']);
  82. $expected = [
  83. [
  84. 'message' => 'This is a test message',
  85. 'key' => 'foobar',
  86. 'element' => 'flash/default',
  87. 'params' => [],
  88. ],
  89. ];
  90. $result = $this->Session->read('Flash.foobar');
  91. $this->assertEquals($expected, $result);
  92. }
  93. public function testDefaultParamsOverriding(): void
  94. {
  95. $this->Flash = new FlashMessage(
  96. $this->Session,
  97. ['params' => ['foo' => 'bar']]
  98. );
  99. $this->Flash->set(
  100. 'This is a test message',
  101. ['params' => ['username' => 'ADmad']]
  102. );
  103. $expected[] = [
  104. 'message' => 'This is a test message',
  105. 'key' => 'flash',
  106. 'element' => 'flash/default',
  107. 'params' => ['username' => 'ADmad'],
  108. ];
  109. $result = $this->Session->read('Flash.flash');
  110. $this->assertEquals($expected, $result);
  111. }
  112. public function testDuplicateIgnored(): void
  113. {
  114. $this->assertNull($this->Session->read('Flash.flash'));
  115. $this->Flash->setConfig('duplicate', false);
  116. $this->Flash->set('This test message should appear once only');
  117. $this->Flash->set('This test message should appear once only');
  118. $result = $this->Session->read('Flash.flash');
  119. $this->assertCount(1, $result);
  120. }
  121. public function testSetEscape(): void
  122. {
  123. $this->assertNull($this->Session->read('Flash.flash'));
  124. $this->Flash->set(
  125. 'This is a <b>test</b> message',
  126. ['escape' => false, 'params' => ['foo' => 'bar']]
  127. );
  128. $expected = [
  129. [
  130. 'message' => 'This is a <b>test</b> message',
  131. 'key' => 'flash',
  132. 'element' => 'flash/default',
  133. 'params' => ['foo' => 'bar', 'escape' => false],
  134. ],
  135. ];
  136. $result = $this->Session->read('Flash.flash');
  137. $this->assertEquals($expected, $result);
  138. $this->Flash->set(
  139. 'This is a test message',
  140. ['key' => 'escaped', 'escape' => false, 'params' => ['foo' => 'bar', 'escape' => true]]
  141. );
  142. $expected = [
  143. [
  144. 'message' => 'This is a test message',
  145. 'key' => 'escaped',
  146. 'element' => 'flash/default',
  147. 'params' => ['foo' => 'bar', 'escape' => true],
  148. ],
  149. ];
  150. $result = $this->Session->read('Flash.escaped');
  151. $this->assertEquals($expected, $result);
  152. }
  153. public function testSetWithClear(): void
  154. {
  155. $this->assertNull($this->Session->read('Flash.flash'));
  156. $this->Flash->set('This is a test message');
  157. $expected = [
  158. [
  159. 'message' => 'This is a test message',
  160. 'key' => 'flash',
  161. 'element' => 'flash/default',
  162. 'params' => [],
  163. ],
  164. ];
  165. $result = $this->Session->read('Flash.flash');
  166. $this->assertEquals($expected, $result);
  167. $this->Flash->set('This is another test message', ['clear' => true]);
  168. $expected = [
  169. [
  170. 'message' => 'This is another test message',
  171. 'key' => 'flash',
  172. 'element' => 'flash/default',
  173. 'params' => [],
  174. ],
  175. ];
  176. $result = $this->Session->read('Flash.flash');
  177. $this->assertEquals($expected, $result);
  178. }
  179. public function testSetWithPlugin(): void
  180. {
  181. $this->Flash->set('This is a test message', ['plugin' => 'FooBar']);
  182. $expected = [
  183. [
  184. 'message' => 'This is a test message',
  185. 'key' => 'flash',
  186. 'element' => 'FooBar.flash/default',
  187. 'params' => [],
  188. ],
  189. ];
  190. $result = $this->Session->read('Flash.flash');
  191. $this->assertEquals($expected, $result);
  192. // Value of 'plugin' will override the plugin name used in 'element'
  193. $this->Flash->set('This is a test message', [
  194. 'key' => 'msg',
  195. 'element' => 'Plugin.success',
  196. 'plugin' => 'FooBar',
  197. ]);
  198. $expected = [
  199. [
  200. 'message' => 'This is a test message',
  201. 'key' => 'msg',
  202. 'element' => 'FooBar.flash/success',
  203. 'params' => [],
  204. ],
  205. ];
  206. $result = $this->Session->read('Flash.msg');
  207. $this->assertEquals($expected, $result);
  208. }
  209. public function testSetExceptionMessage(): void
  210. {
  211. $this->assertNull($this->Session->read('Flash.flash'));
  212. $this->Flash->setExceptionMessage(new Exception('This is a test message', 404));
  213. $expected = [
  214. [
  215. 'message' => 'This is a test message',
  216. 'key' => 'flash',
  217. 'element' => 'flash/error',
  218. 'params' => ['code' => 404],
  219. ],
  220. ];
  221. $result = $this->Session->read('Flash.flash');
  222. $this->assertEquals($expected, $result);
  223. $this->Flash->setExceptionMessage(
  224. new Exception('This is a test message'),
  225. ['element' => 'default', 'clear' => true]
  226. );
  227. $expected = [
  228. [
  229. 'message' => 'This is a test message',
  230. 'key' => 'flash',
  231. 'element' => 'flash/default',
  232. 'params' => ['code' => null],
  233. ],
  234. ];
  235. $result = $this->Session->read('Flash.flash');
  236. $this->assertEquals($expected, $result);
  237. }
  238. public function testSetWithConstructorConfiguration(): void
  239. {
  240. $this->assertNull($this->Session->read('Flash.flash'));
  241. $flash = new FlashMessage($this->Session, ['element' => 'test']);
  242. $flash->set('This is a test message');
  243. $expected = [
  244. [
  245. 'message' => 'This is a test message',
  246. 'key' => 'flash',
  247. 'element' => 'flash/test',
  248. 'params' => [],
  249. ],
  250. ];
  251. $result = $this->Session->read('Flash.flash');
  252. $this->assertEquals($expected, $result);
  253. }
  254. /**
  255. * @dataProvider convenienceMethods
  256. */
  257. public function testConvenienceMethods(string $type): void
  258. {
  259. $this->assertNull($this->Session->read('Flash.flash'));
  260. $this->Flash->{$type}('It worked');
  261. $expected = [
  262. [
  263. 'message' => 'It worked',
  264. 'key' => 'flash',
  265. 'element' => 'flash/' . $type,
  266. 'params' => [],
  267. ],
  268. ];
  269. $result = $this->Session->read('Flash.flash');
  270. $this->assertEquals($expected, $result);
  271. }
  272. public static function convenienceMethods(): array
  273. {
  274. return [
  275. ['success'],
  276. ['error'],
  277. ['warning'],
  278. ['info'],
  279. ];
  280. }
  281. public function testSuccessWithClear(): void
  282. {
  283. $this->assertNull($this->Session->read('Flash.flash'));
  284. $this->Flash->success('It worked');
  285. $expected = [
  286. [
  287. 'message' => 'It worked',
  288. 'key' => 'flash',
  289. 'element' => 'flash/success',
  290. 'params' => [],
  291. ],
  292. ];
  293. $result = $this->Session->read('Flash.flash');
  294. $this->assertEquals($expected, $result);
  295. $this->Flash->success('It worked too', ['clear' => true]);
  296. $expected = [
  297. [
  298. 'message' => 'It worked too',
  299. 'key' => 'flash',
  300. 'element' => 'flash/success',
  301. 'params' => [],
  302. ],
  303. ];
  304. $result = $this->Session->read('Flash.flash');
  305. $this->assertEquals($expected, $result);
  306. }
  307. public function testError(): void
  308. {
  309. $this->assertNull($this->Session->read('Flash.flash'));
  310. $this->Flash->error('It did not work', ['element' => 'error_thing']);
  311. $expected[] = [
  312. 'message' => 'It did not work',
  313. 'key' => 'flash',
  314. 'element' => 'flash/error',
  315. 'params' => [],
  316. ];
  317. $result = $this->Session->read('Flash.flash');
  318. $this->assertEquals($expected, $result, 'Element is ignored in convenience method call.');
  319. }
  320. }