|
|
@@ -5,114 +5,123 @@ namespace App\Test\Service\Access;
|
|
|
use App\Entity\Access\Access;
|
|
|
use App\Entity\Organization\Organization;
|
|
|
use App\Repository\Access\AccessRepository;
|
|
|
-use App\Service\Access\HandleOptionalsRoles;
|
|
|
-use App\Service\Access\Utils;
|
|
|
+use App\Service\Access\Utils as AccessUtils;
|
|
|
use App\Service\ServiceIterator\OptionalsRolesIterator;
|
|
|
+use PHPUnit\Framework\MockObject\MockObject;
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
use Symfony\Component\Security\Core\Role\RoleHierarchy;
|
|
|
|
|
|
class UtilsTest extends TestCase
|
|
|
{
|
|
|
- private Utils $utils;
|
|
|
- private AccessRepository $accessRepositoryMock;
|
|
|
+ private MockObject | RoleHierarchy $roleHierarchy;
|
|
|
+ private MockObject | OptionalsRolesIterator $optionalsRolesIterator;
|
|
|
+ private MockObject | AccessRepository $accessRepository;
|
|
|
|
|
|
public function setUp():void
|
|
|
{
|
|
|
- $roleHierarchyMock = $this->getMockBuilder(RoleHierarchy::class)->disableOriginalConstructor()->getMock();
|
|
|
- $roleHierarchyMock
|
|
|
- ->method('getReachableRoleNames')
|
|
|
- ->willReturn(["ROLE_A", "ROLE_B"]);
|
|
|
-
|
|
|
-
|
|
|
- $optionalsRolesIteratorMock = $this->getMockBuilder(OptionalsRolesIterator::class)->disableOriginalConstructor()->getMock();
|
|
|
- $optionalsRolesIteratorMock
|
|
|
- ->method('getOptionalsRoles')
|
|
|
- ->willReturn(["ROLE_OPT"]);
|
|
|
-
|
|
|
- $this->accessRepositoryMock = $this->getMockBuilder(AccessRepository::class)->disableOriginalConstructor()->getMock();
|
|
|
-
|
|
|
- $this->utils = new Utils($roleHierarchyMock, $this->accessRepositoryMock, $optionalsRolesIteratorMock);
|
|
|
+ $this->roleHierarchy = $this->getMockBuilder(RoleHierarchy::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $this->optionalsRolesIterator = $this->getMockBuilder(OptionalsRolesIterator::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $this->accessRepository = $this->getMockBuilder(AccessRepository::class)->disableOriginalConstructor()->getMock();
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* @see Utils::filterAccesses()
|
|
|
*/
|
|
|
- public function testFilterAccesses(){
|
|
|
- $accessMock1 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
- $accessMock1
|
|
|
- ->method('getId')
|
|
|
- ->willReturn(1);
|
|
|
- $accessesMock[] = $accessMock1;
|
|
|
- $accessMock2 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
- $accessMock2
|
|
|
- ->method('getId')
|
|
|
- ->willReturn(2);
|
|
|
- $accessesMock[] = $accessMock2;
|
|
|
- $accessMock3 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
- $accessMock3
|
|
|
- ->method('getId')
|
|
|
- ->willReturn(3);
|
|
|
- $accessesMock[] = $accessMock3;
|
|
|
-
|
|
|
- $this->assertCount(2, $this->utils->filterAccesses($accessesMock, $accessMock2));
|
|
|
- }
|
|
|
+ public function testFilterAccesses(): void
|
|
|
+ {
|
|
|
+ $accessUtils = $this->getMockBuilder(AccessUtils::class)
|
|
|
+ ->setConstructorArgs([$this->roleHierarchy, $this->accessRepository, $this->optionalsRolesIterator])
|
|
|
+ ->setMethodsExcept(['filterAccesses'])
|
|
|
+ ->getMock();
|
|
|
|
|
|
- /**
|
|
|
- * @see Utils::hasRoles()
|
|
|
- */
|
|
|
- public function testHasRoles(){
|
|
|
- $accessMock1 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
- $accessMock1
|
|
|
- ->method('getRoles')
|
|
|
- ->willReturn(['ROLE_A']);
|
|
|
+ $access1 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $access1->method('getId')->willReturn(1);
|
|
|
+
|
|
|
+ $access2 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $access2->method('getId')->willReturn(2);
|
|
|
+
|
|
|
+ $access3 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $access3->method('getId')->willReturn(3);
|
|
|
+
|
|
|
+ $accesses = [$access1, $access2, $access3];
|
|
|
+
|
|
|
+ $result = $accessUtils->filterAccesses($accesses, $access2);
|
|
|
|
|
|
- $this->assertTrue($this->utils->hasRoles($accessMock1, 'ROLE_A'));
|
|
|
+ $this->assertEqualsCanonicalizing(
|
|
|
+ [$access1->getId(), $access3->getId()],
|
|
|
+ array_map(static function ($access) { return $access->getId(); }, $result)
|
|
|
+ );
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* @see Utils::hasRoles()
|
|
|
*/
|
|
|
- public function testHasNotRoles(){
|
|
|
- $accessMock1 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
- $accessMock1
|
|
|
- ->method('getRoles')
|
|
|
- ->willReturn(['ROLE_A']);
|
|
|
+ public function testHasRoles(): void
|
|
|
+ {
|
|
|
+ $accessUtils = $this->getMockBuilder(AccessUtils::class)
|
|
|
+ ->setConstructorArgs([$this->roleHierarchy, $this->accessRepository, $this->optionalsRolesIterator])
|
|
|
+ ->setMethodsExcept(['hasRoles'])
|
|
|
+ ->getMock();
|
|
|
|
|
|
- $this->assertFalse($this->utils->hasRoles($accessMock1, 'ROLE_X'));
|
|
|
- }
|
|
|
+ $access = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
|
|
|
+ $accessUtils->method('getAllRoles')->with($access)->willReturn(['ROLE_A']);
|
|
|
+
|
|
|
+ $this->assertTrue($accessUtils->hasRoles($access, 'ROLE_A'));
|
|
|
+ $this->assertFalse($accessUtils->hasRoles($access, 'ROLE_B'));
|
|
|
+ }
|
|
|
|
|
|
/**
|
|
|
* @see Utils::getAllRoles()
|
|
|
*/
|
|
|
- public function testGetAllRoles(){
|
|
|
- $accessMock1 = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
- $accessMock1
|
|
|
- ->method('getRoles')
|
|
|
- ->willReturn(['ROLE_A']);
|
|
|
+ public function testGetAllRoles(): void
|
|
|
+ {
|
|
|
+ $accessUtils = $this->getMockBuilder(AccessUtils::class)
|
|
|
+ ->setConstructorArgs([$this->roleHierarchy, $this->accessRepository, $this->optionalsRolesIterator])
|
|
|
+ ->setMethodsExcept(['getAllRoles'])
|
|
|
+ ->getMock();
|
|
|
+
|
|
|
+ $access = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $access->method('getRoles')->willReturn(['ROLE_A']);
|
|
|
+
|
|
|
+ $this->roleHierarchy->method('getReachableRoleNames')->willReturn(["ROLE_A", "ROLE_B"]);
|
|
|
+ $this->optionalsRolesIterator->method('getOptionalsRoles')->willReturn(["ROLE_OPT"]);
|
|
|
|
|
|
- $this->assertEquals(['ROLE_A', 'ROLE_B'], $this->utils->getAllRoles($accessMock1));
|
|
|
+ $this->assertEquals(['ROLE_A', 'ROLE_B'], $accessUtils->getAllRoles($access));
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* @see Utils::findAdminFor()
|
|
|
*/
|
|
|
- public function testFindAdminFor(){
|
|
|
- $this->accessRepositoryMock
|
|
|
- ->method('findOneBy')
|
|
|
- ->willReturn(new Access());
|
|
|
+ public function testFindAdminFor(): void
|
|
|
+ {
|
|
|
+ $accessUtils = $this->getMockBuilder(AccessUtils::class)
|
|
|
+ ->setConstructorArgs([$this->roleHierarchy, $this->accessRepository, $this->optionalsRolesIterator])
|
|
|
+ ->setMethodsExcept(['findAdminFor'])
|
|
|
+ ->getMock();
|
|
|
+
|
|
|
+ $access = $this->getMockBuilder(Access::class)->disableOriginalConstructor()->getMock();
|
|
|
+ $organization = $this->getMockBuilder(Organization::class)->disableOriginalConstructor()->getMock();
|
|
|
+
|
|
|
+ $this->accessRepository->method('findOneBy')->with(['adminAccess' => true, 'organization' => $organization])->willReturn($access);
|
|
|
|
|
|
- $this->assertNotEmpty($this->utils->findAdminFor(new Organization()));
|
|
|
+ $this->assertNotEmpty($accessUtils->findAdminFor($organization));
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* @see Utils::findAdminFor()
|
|
|
*/
|
|
|
- public function testFindAdminForNotFound(){
|
|
|
- $this->accessRepositoryMock
|
|
|
- ->method('findOneBy')
|
|
|
- ->willReturn(null);
|
|
|
+ public function testFindAdminForNotFound(): void
|
|
|
+ {
|
|
|
+ $accessUtils = $this->getMockBuilder(AccessUtils::class)
|
|
|
+ ->setConstructorArgs([$this->roleHierarchy, $this->accessRepository, $this->optionalsRolesIterator])
|
|
|
+ ->setMethodsExcept(['findAdminFor'])
|
|
|
+ ->getMock();
|
|
|
+
|
|
|
+ $organization = $this->getMockBuilder(Organization::class)->disableOriginalConstructor()->getMock();
|
|
|
+
|
|
|
+ $this->accessRepository->method('findOneBy')->with(['adminAccess' => true, 'organization' => $organization])->willReturn(null);
|
|
|
|
|
|
- $this->assertNull($this->utils->findAdminFor(new Organization()));
|
|
|
+ $this->assertNull($accessUtils->findAdminFor($organization));
|
|
|
}
|
|
|
}
|