MiddlewareQueueTest.php 11 KB

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