MiddlewareQueueTest.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420
  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 3.3.0
  14. * @license https://opensource.org/licenses/mit-license.php MIT License
  15. */
  16. namespace Cake\Test\TestCase\Http;
  17. use Cake\Http\MiddlewareQueue;
  18. use Cake\TestSuite\TestCase;
  19. use TestApp\Middleware\DumbMiddleware;
  20. use TestApp\Middleware\SampleMiddleware;
  21. /**
  22. * Test case for the MiddlewareQueue
  23. */
  24. class MiddlewareQueueTest extends TestCase
  25. {
  26. /**
  27. * setUp
  28. *
  29. * @return void
  30. */
  31. public function setUp(): void
  32. {
  33. parent::setUp();
  34. $this->previousNamespace = static::setAppNamespace('TestApp');
  35. }
  36. /**
  37. * tearDown
  38. *
  39. * @return void
  40. */
  41. public function tearDown(): void
  42. {
  43. parent::tearDown();
  44. static::setAppNamespace($this->previousNamespace);
  45. }
  46. public function testConstructorAddingMiddleware()
  47. {
  48. $cb = function () {
  49. };
  50. $queue = new MiddlewareQueue([$cb]);
  51. $this->assertCount(1, $queue);
  52. $this->assertSame($cb, $queue->current()->getCallable());
  53. }
  54. /**
  55. * Test get()
  56. *
  57. * @return void
  58. */
  59. public function testGet()
  60. {
  61. $queue = new MiddlewareQueue();
  62. $cb = function () {
  63. };
  64. $queue->add($cb);
  65. $this->assertSame($cb, $queue->current()->getCallable());
  66. }
  67. /**
  68. * Test that current() throws exception for invalid current position.
  69. *
  70. * @return void
  71. */
  72. public function testGetException()
  73. {
  74. $this->expectException(\OutOfBoundsException::class);
  75. $this->expectExceptionMessage('Invalid current position (0)');
  76. $queue = new MiddlewareQueue();
  77. $queue->current();
  78. }
  79. /**
  80. * Test the return value of add()
  81. *
  82. * @return void
  83. */
  84. public function testAddReturn()
  85. {
  86. $queue = new MiddlewareQueue();
  87. $cb = function () {
  88. };
  89. $this->assertSame($queue, $queue->add($cb));
  90. }
  91. /**
  92. * Test the add orders correctly
  93. *
  94. * @return void
  95. */
  96. public function testAddOrdering()
  97. {
  98. $one = function () {
  99. };
  100. $two = function () {
  101. };
  102. $queue = new MiddlewareQueue();
  103. $this->assertCount(0, $queue);
  104. $queue->add($one);
  105. $this->assertCount(1, $queue);
  106. $queue->add($two);
  107. $this->assertCount(2, $queue);
  108. $this->assertSame($one, $queue->current()->getCallable());
  109. $queue->next();
  110. $this->assertSame($two, $queue->current()->getCallable());
  111. }
  112. /**
  113. * Test the prepend can be chained
  114. *
  115. * @return void
  116. */
  117. public function testPrependReturn()
  118. {
  119. $cb = function () {
  120. };
  121. $queue = new MiddlewareQueue();
  122. $this->assertSame($queue, $queue->prepend($cb));
  123. }
  124. /**
  125. * Test the prepend orders correctly.
  126. *
  127. * @return void
  128. */
  129. public function testPrependOrdering()
  130. {
  131. $one = function () {
  132. };
  133. $two = function () {
  134. };
  135. $queue = new MiddlewareQueue();
  136. $this->assertCount(0, $queue);
  137. $queue->add($one);
  138. $this->assertCount(1, $queue);
  139. $queue->prepend($two);
  140. $this->assertCount(2, $queue);
  141. $this->assertSame($two, $queue->current()->getCallable());
  142. $queue->next();
  143. $this->assertSame($one, $queue->current()->getCallable());
  144. }
  145. /**
  146. * Test updating queue using class name
  147. *
  148. * @return void
  149. */
  150. public function testAddingPrependingUsingString()
  151. {
  152. $queue = new MiddlewareQueue();
  153. $queue->add('Sample');
  154. $queue->prepend('TestApp\Middleware\SampleMiddleware');
  155. $this->assertInstanceOf('TestApp\Middleware\SampleMiddleware', $queue->current());
  156. $this->assertInstanceOf('TestApp\Middleware\SampleMiddleware', $queue->current());
  157. }
  158. /**
  159. * Test updating queue using array
  160. *
  161. * @return void
  162. */
  163. public function testAddingPrependingUsingArray()
  164. {
  165. $one = function () {
  166. };
  167. $queue = new MiddlewareQueue();
  168. $queue->add([$one]);
  169. $queue->prepend(['TestApp\Middleware\SampleMiddleware']);
  170. $this->assertInstanceOf('TestApp\Middleware\SampleMiddleware', $queue->current());
  171. $queue->next();
  172. $this->assertSame($one, $queue->current()->getCallable());
  173. }
  174. /**
  175. * Test insertAt ordering
  176. *
  177. * @return void
  178. */
  179. public function testInsertAt()
  180. {
  181. $one = function () {
  182. };
  183. $two = function () {
  184. };
  185. $three = function () {
  186. };
  187. $four = new SampleMiddleware();
  188. $queue = new MiddlewareQueue();
  189. $queue->add($one)->add($two)->insertAt(0, $three)->insertAt(2, $four);
  190. $this->assertSame($three, $queue->current()->getCallable());
  191. $queue->next();
  192. $this->assertSame($one, $queue->current()->getCallable());
  193. $queue->next();
  194. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  195. $queue->next();
  196. $this->assertSame($two, $queue->current()->getCallable());
  197. $queue = new MiddlewareQueue();
  198. $queue->add($one)->add($two)->insertAt(1, $three);
  199. $this->assertSame($one, $queue->current()->getCallable());
  200. $queue->next();
  201. $this->assertSame($three, $queue->current()->getCallable());
  202. $queue->next();
  203. $this->assertSame($two, $queue->current()->getCallable());
  204. }
  205. /**
  206. * Test insertAt out of the existing range
  207. *
  208. * @return void
  209. */
  210. public function testInsertAtOutOfBounds()
  211. {
  212. $one = function () {
  213. };
  214. $two = function () {
  215. };
  216. $queue = new MiddlewareQueue();
  217. $queue->add($one)->insertAt(99, $two);
  218. $this->assertCount(2, $queue);
  219. $this->assertSame($one, $queue->current()->getCallable());
  220. $queue->next();
  221. $this->assertSame($two, $queue->current()->getCallable());
  222. }
  223. /**
  224. * Test insertAt with a negative index
  225. *
  226. * @return void
  227. */
  228. public function testInsertAtNegative()
  229. {
  230. $one = function () {
  231. };
  232. $two = function () {
  233. };
  234. $three = new SampleMiddleware();
  235. $queue = new MiddlewareQueue();
  236. $queue->add($one)->insertAt(-1, $two)->insertAt(-1, $three);
  237. $this->assertCount(3, $queue);
  238. $this->assertSame($two, $queue->current()->getCallable());
  239. $queue->next();
  240. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  241. $queue->next();
  242. $this->assertSame($one, $queue->current()->getCallable());
  243. }
  244. /**
  245. * Test insertBefore
  246. *
  247. * @return void
  248. */
  249. public function testInsertBefore()
  250. {
  251. $one = function () {
  252. };
  253. $two = new SampleMiddleware();
  254. $three = function () {
  255. };
  256. $four = new DumbMiddleware();
  257. $queue = new MiddlewareQueue();
  258. $queue->add($one)->add($two)->insertBefore(SampleMiddleware::class, $three)->insertBefore(SampleMiddleware::class, $four);
  259. $this->assertCount(4, $queue);
  260. $this->assertSame($one, $queue->current()->getCallable());
  261. $queue->next();
  262. $this->assertSame($three, $queue->current()->getCallable());
  263. $queue->next();
  264. $this->assertInstanceOf(DumbMiddleware::class, $queue->current());
  265. $queue->next();
  266. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  267. $two = SampleMiddleware::class;
  268. $queue = new MiddlewareQueue();
  269. $queue
  270. ->add($one)
  271. ->add($two)
  272. ->insertBefore(SampleMiddleware::class, $three);
  273. $this->assertCount(3, $queue);
  274. $this->assertSame($one, $queue->current()->getCallable());
  275. $queue->next();
  276. $this->assertSame($three, $queue->current()->getCallable());
  277. $queue->next();
  278. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  279. }
  280. /**
  281. * Test insertBefore an invalid classname
  282. *
  283. * @return void
  284. */
  285. public function testInsertBeforeInvalid()
  286. {
  287. $this->expectException(\LogicException::class);
  288. $this->expectExceptionMessage('No middleware matching \'InvalidClassName\' could be found.');
  289. $one = function () {
  290. };
  291. $two = new SampleMiddleware();
  292. $three = function () {
  293. };
  294. $queue = new MiddlewareQueue();
  295. $queue->add($one)->add($two)->insertBefore('InvalidClassName', $three);
  296. }
  297. /**
  298. * Test insertAfter
  299. *
  300. * @return void
  301. */
  302. public function testInsertAfter()
  303. {
  304. $one = new SampleMiddleware();
  305. $two = function () {
  306. };
  307. $three = function () {
  308. };
  309. $four = new DumbMiddleware();
  310. $queue = new MiddlewareQueue();
  311. $queue
  312. ->add($one)
  313. ->add($two)
  314. ->insertAfter(SampleMiddleware::class, $three)
  315. ->insertAfter(SampleMiddleware::class, $four);
  316. $this->assertCount(4, $queue);
  317. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  318. $queue->next();
  319. $this->assertInstanceOf(DumbMiddleware::class, $queue->current());
  320. $queue->next();
  321. $this->assertSame($three, $queue->current()->getCallable());
  322. $queue->next();
  323. $this->assertSame($two, $queue->current()->getCallable());
  324. $one = 'Sample';
  325. $queue = new MiddlewareQueue();
  326. $queue
  327. ->add($one)
  328. ->add($two)
  329. ->insertAfter('Sample', $three);
  330. $this->assertCount(3, $queue);
  331. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  332. $queue->next();
  333. $this->assertSame($three, $queue->current()->getCallable());
  334. $queue->next();
  335. $this->assertSame($two, $queue->current()->getCallable());
  336. }
  337. /**
  338. * Test insertAfter an invalid classname
  339. *
  340. * @return void
  341. */
  342. public function testInsertAfterInvalid()
  343. {
  344. $one = new SampleMiddleware();
  345. $two = function () {
  346. };
  347. $three = function () {
  348. };
  349. $queue = new MiddlewareQueue();
  350. $queue->add($one)->add($two)->insertAfter('InvalidClass', $three);
  351. $this->assertCount(3, $queue);
  352. $this->assertInstanceOf(SampleMiddleware::class, $queue->current());
  353. $queue->next();
  354. $this->assertSame($two, $queue->current()->getCallable());
  355. $queue->next();
  356. $this->assertSame($three, $queue->current()->getCallable());
  357. }
  358. /**
  359. * @deprecated
  360. */
  361. public function testAddingDeprecatedDoublePassMiddleware()
  362. {
  363. $queue = new MiddlewareQueue();
  364. $cb = function ($request, $response, $next) {
  365. return $next($request, $response);
  366. };
  367. $queue->add($cb);
  368. $this->deprecated(function () use ($queue, $cb) {
  369. $this->assertSame($cb, $queue->current()->getCallable());
  370. });
  371. }
  372. }