InternalRequestsServiceTest.php 5.6 KB

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