RunnerTest.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  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\Http\Response;
  19. use Cake\Http\Runner;
  20. use Cake\TestSuite\TestCase;
  21. use Psr\Http\Message\ResponseInterface;
  22. use RuntimeException;
  23. /**
  24. * Test case for runner.
  25. */
  26. class RunnerTest extends TestCase
  27. {
  28. /**
  29. * @var \Cake\Http\MiddlewareQueue
  30. */
  31. protected $queue;
  32. /**
  33. * @var \Closure
  34. */
  35. protected $ok;
  36. /**
  37. * @var \Closure
  38. */
  39. protected $pass;
  40. /**
  41. * @var \Closure
  42. */
  43. protected $fail;
  44. /**
  45. * setup
  46. */
  47. public function setUp(): void
  48. {
  49. parent::setUp();
  50. $this->queue = new MiddlewareQueue();
  51. $this->ok = function ($request, $handler) {
  52. return $handler->handle($request);
  53. };
  54. $this->pass = function ($request, $handler) {
  55. return $handler->handle($request);
  56. };
  57. $this->fail = function ($request, $handler): void {
  58. throw new RuntimeException('A bad thing');
  59. };
  60. }
  61. /**
  62. * Test running a single middleware object.
  63. */
  64. public function testRunSingle(): void
  65. {
  66. $this->queue->add($this->ok);
  67. $req = $this->getMockBuilder('Psr\Http\Message\ServerRequestInterface')->getMock();
  68. $runner = new Runner();
  69. $result = $runner->run($this->queue, $req);
  70. $this->assertInstanceof(ResponseInterface::class, $result);
  71. }
  72. /**
  73. * Test that middleware is run in sequence
  74. */
  75. public function testRunSequencing(): void
  76. {
  77. $log = [];
  78. $one = function ($request, $handler) use (&$log) {
  79. $log[] = 'one';
  80. return $handler->handle($request);
  81. };
  82. $two = function ($request, $handler) use (&$log) {
  83. $log[] = 'two';
  84. return $handler->handle($request);
  85. };
  86. $three = function ($request, $handler) use (&$log) {
  87. $log[] = 'three';
  88. return $handler->handle($request);
  89. };
  90. $this->queue->add($one)->add($two)->add($three);
  91. $runner = new Runner();
  92. $req = $this->getMockBuilder('Psr\Http\Message\ServerRequestInterface')->getMock();
  93. $result = $runner->run($this->queue, $req);
  94. $this->assertInstanceof(Response::class, $result);
  95. $expected = ['one', 'two', 'three'];
  96. $this->assertEquals($expected, $log);
  97. }
  98. /**
  99. * Test that exceptions bubble up.
  100. */
  101. public function testRunExceptionInMiddleware(): void
  102. {
  103. $this->expectException(RuntimeException::class);
  104. $this->expectExceptionMessage('A bad thing');
  105. $this->queue->add($this->ok)->add($this->fail);
  106. $req = $this->getMockBuilder('Psr\Http\Message\ServerRequestInterface')->getMock();
  107. $runner = new Runner();
  108. $runner->run($this->queue, $req);
  109. }
  110. }