EncryptCookiesTest.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. namespace Illuminate\Tests\Cookie\Middleware;
  3. use Illuminate\Container\Container;
  4. use Illuminate\Contracts\Encryption\Encrypter as EncrypterContract;
  5. use Illuminate\Cookie\CookieJar;
  6. use Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse;
  7. use Illuminate\Cookie\Middleware\EncryptCookies;
  8. use Illuminate\Encryption\Encrypter;
  9. use Illuminate\Events\Dispatcher;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Http\Response;
  12. use Illuminate\Routing\Controller;
  13. use Illuminate\Routing\Router;
  14. use PHPUnit\Framework\TestCase;
  15. use Symfony\Component\HttpFoundation\Cookie;
  16. class EncryptCookiesTest extends TestCase
  17. {
  18. /**
  19. * @var \Illuminate\Routing\Router
  20. */
  21. protected $router;
  22. protected $setCookiePath = 'cookie/set';
  23. protected $queueCookiePath = 'cookie/queue';
  24. protected function setUp(): void
  25. {
  26. parent::setUp();
  27. $container = new Container;
  28. $container->singleton(EncrypterContract::class, function () {
  29. return new Encrypter(str_repeat('a', 16));
  30. });
  31. $this->router = new Router(new Dispatcher, $container);
  32. }
  33. public function testSetCookieEncryption()
  34. {
  35. $this->router->get($this->setCookiePath, [
  36. 'middleware' => EncryptCookiesTestMiddleware::class,
  37. 'uses' => EncryptCookiesTestController::class.'@setCookies',
  38. ]);
  39. $response = $this->router->dispatch(Request::create($this->setCookiePath, 'GET'));
  40. $cookies = $response->headers->getCookies();
  41. $this->assertCount(2, $cookies);
  42. $this->assertSame('encrypted_cookie', $cookies[0]->getName());
  43. $this->assertNotSame('value', $cookies[0]->getValue());
  44. $this->assertSame('unencrypted_cookie', $cookies[1]->getName());
  45. $this->assertSame('value', $cookies[1]->getValue());
  46. }
  47. public function testQueuedCookieEncryption()
  48. {
  49. $this->router->get($this->queueCookiePath, [
  50. 'middleware' => [EncryptCookiesTestMiddleware::class, AddQueuedCookiesToResponseTestMiddleware::class],
  51. 'uses' => EncryptCookiesTestController::class.'@queueCookies',
  52. ]);
  53. $response = $this->router->dispatch(Request::create($this->queueCookiePath, 'GET'));
  54. $cookies = $response->headers->getCookies();
  55. $this->assertCount(2, $cookies);
  56. $this->assertSame('encrypted_cookie', $cookies[0]->getName());
  57. $this->assertNotSame('value', $cookies[0]->getValue());
  58. $this->assertSame('unencrypted_cookie', $cookies[1]->getName());
  59. $this->assertSame('value', $cookies[1]->getValue());
  60. }
  61. }
  62. class EncryptCookiesTestController extends Controller
  63. {
  64. public function setCookies()
  65. {
  66. $response = new Response;
  67. $response->headers->setCookie(new Cookie('encrypted_cookie', 'value'));
  68. $response->headers->setCookie(new Cookie('unencrypted_cookie', 'value'));
  69. return $response;
  70. }
  71. public function queueCookies()
  72. {
  73. return new Response;
  74. }
  75. }
  76. class EncryptCookiesTestMiddleware extends EncryptCookies
  77. {
  78. protected $except = [
  79. 'unencrypted_cookie',
  80. ];
  81. }
  82. class AddQueuedCookiesToResponseTestMiddleware extends AddQueuedCookiesToResponse
  83. {
  84. public function __construct()
  85. {
  86. $cookie = new CookieJar;
  87. $cookie->queue(new Cookie('encrypted_cookie', 'value'));
  88. $cookie->queue(new Cookie('unencrypted_cookie', 'value'));
  89. $this->cookies = $cookie;
  90. }
  91. }