InternalRequestsServiceTest.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. namespace App\Tests\Unit\Service\Security;
  3. use App\Service\Security\InternalRequestsService;
  4. use PHPUnit\Framework\MockObject\MockObject;
  5. use PHPUnit\Framework\TestCase;
  6. use Symfony\Bundle\SecurityBundle\Security;
  7. class TestableInternalRequestsService extends InternalRequestsService
  8. {
  9. public function isInternalIp(string $ip): bool
  10. {
  11. return parent::isInternalIp($ip);
  12. }
  13. public function tokenIsValid(string|null $token): bool
  14. {
  15. return parent::tokenIsValid($token);
  16. }
  17. }
  18. class InternalRequestsServiceTest extends TestCase
  19. {
  20. public const internalRequestsToken = 'azerty';
  21. private Security $security;
  22. public function setUp(): void
  23. {
  24. $this->security = $this->getMockBuilder(Security::class)->disableOriginalConstructor()->getMock();
  25. }
  26. private function getInternalRequestsServiceMockFor(string $methodName, ?string $token = null): TestableInternalRequestsService|MockObject
  27. {
  28. return $this->getMockBuilder(TestableInternalRequestsService::class)
  29. ->setConstructorArgs([$token ?? self::internalRequestsToken, $this->security])
  30. ->setMethodsExcept([$methodName])
  31. ->getMock();
  32. }
  33. public function testIsInternalIp(): void
  34. {
  35. $internalRequestsService = $this->getInternalRequestsServiceMockFor('isInternalIp');
  36. $this->assertTrue($internalRequestsService->isInternalIp('127.0.0.0'));
  37. $this->assertTrue($internalRequestsService->isInternalIp('127.0.0.1'));
  38. $this->assertTrue($internalRequestsService->isInternalIp('10.8.0.1'));
  39. $this->assertTrue($internalRequestsService->isInternalIp('10.8.0.255'));
  40. $this->assertFalse($internalRequestsService->isInternalIp('141.94.117.32'));
  41. $this->assertTrue($internalRequestsService->isInternalIp('141.94.117.33'));
  42. $this->assertTrue($internalRequestsService->isInternalIp('141.94.117.50'));
  43. $this->assertTrue($internalRequestsService->isInternalIp('141.94.117.61'));
  44. $this->assertFalse($internalRequestsService->isInternalIp('141.94.117.62'));
  45. $this->assertTrue($internalRequestsService->isInternalIp('172.20.0.0'));
  46. $this->assertTrue($internalRequestsService->isInternalIp('172.20.255.255'));
  47. }
  48. public function testTokenIsValid(): void
  49. {
  50. $internalRequestsService = $this->getInternalRequestsServiceMockFor('tokenIsValid');
  51. $this->assertTrue($internalRequestsService->tokenIsValid(self::internalRequestsToken));
  52. $this->assertFalse($internalRequestsService->tokenIsValid('foo'));
  53. }
  54. public function testTokenIsValidWithEmptyToken(): void
  55. {
  56. $internalRequestsService = $this->getInternalRequestsServiceMockFor('tokenIsValid', '');
  57. // A token can not be valid if it is an empty string, even if it's equal to the internal token
  58. $this->assertFalse($internalRequestsService->tokenIsValid(''));
  59. }
  60. public function testIsAllowed(): void
  61. {
  62. $internalRequestsService = $this->getInternalRequestsServiceMockFor('isAllowed');
  63. $internalRequestsService->expects(self::once())->method('isInternalIp')->with('128.0.0.1')->willReturn(true);
  64. $internalRequestsService->expects(self::once())->method('tokenIsValid')->with('azerty')->willReturn(true);
  65. $result = $internalRequestsService->isAllowed('128.0.0.1', 'azerty');
  66. $this->assertTrue($result);
  67. }
  68. public function testIsAllowedInvalidIp(): void
  69. {
  70. $internalRequestsService = $this->getInternalRequestsServiceMockFor('isAllowed');
  71. $internalRequestsService->expects(self::once())->method('isInternalIp')->with('128.0.0.1')->willReturn(false);
  72. $internalRequestsService->expects(self::never())->method('tokenIsValid');
  73. $result = $internalRequestsService->isAllowed('128.0.0.1', 'azerty');
  74. $this->assertFalse($result);
  75. }
  76. public function testIsAllowedInvalidToken(): void
  77. {
  78. $internalRequestsService = $this->getInternalRequestsServiceMockFor('isAllowed');
  79. $internalRequestsService->expects(self::once())->method('isInternalIp')->with('128.0.0.1')->willReturn(true);
  80. $internalRequestsService->expects(self::once())->method('tokenIsValid')->with('azerty')->willReturn(false);
  81. $result = $internalRequestsService->isAllowed('128.0.0.1', 'azerty');
  82. $this->assertFalse($result);
  83. }
  84. }