mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-09-05 06:14:59 +00:00
Add SHARE permission to SavedExportVoter with tests
Introduced the SHARE attribute and updated SavedExportVoter to handle it. Added new functionality to check if a SavedExport is shared with a specific user and included corresponding unit tests for both the voter and entity behaviors.
This commit is contained in:
@@ -0,0 +1,114 @@
|
||||
<?php
|
||||
|
||||
namespace Chill\MainBundle\Tests\Security\Authorization;
|
||||
|
||||
use Chill\MainBundle\Entity\SavedExport;
|
||||
use Chill\MainBundle\Entity\User;
|
||||
use Chill\MainBundle\Entity\UserGroup;
|
||||
use Chill\MainBundle\Export\ExportInterface;
|
||||
use Chill\MainBundle\Export\ExportManager;
|
||||
use Chill\MainBundle\Security\Authorization\SavedExportVoter;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Prophecy\Argument;
|
||||
use Prophecy\PhpUnit\ProphecyTrait;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
|
||||
use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
|
||||
use Symfony\Component\Security\Core\Security;
|
||||
|
||||
class SavedExportVoterTest extends TestCase
|
||||
{
|
||||
use ProphecyTrait;
|
||||
|
||||
/**
|
||||
* @dataProvider voteProvider
|
||||
*/
|
||||
public function testVote(string $attribute, SavedExport $savedExport, User $user, $expectedResult, bool|null $isGranted = null): void
|
||||
{
|
||||
$security = $this->prophesize(Security::class);
|
||||
if (null !== $isGranted) {
|
||||
$security->isGranted(Argument::any(), Argument::any())->willReturn($isGranted);
|
||||
}
|
||||
|
||||
$export = $this->prophesize(ExportInterface::class);
|
||||
$exportManager = $this->prophesize(ExportManager::class);
|
||||
$exportManager->getExport($savedExport->getExportAlias())->willReturn($export->reveal());
|
||||
|
||||
$voter = new SavedExportVoter($exportManager->reveal(), $security->reveal());
|
||||
$token = new UsernamePasswordToken($user, 'default', ['ROLE_USER']);
|
||||
|
||||
self::assertEquals($expectedResult, $voter->vote($token, $savedExport, [$attribute]));
|
||||
}
|
||||
|
||||
public static function voteProvider(): iterable
|
||||
{
|
||||
$alls = [SavedExportVoter::GENERATE, SavedExportVoter::GENERATE, SavedExportVoter::EDIT, SavedExportVoter::DELETE];
|
||||
$userA = new User();
|
||||
$userB = new User();
|
||||
$userC = new User();
|
||||
$group = new UserGroup();
|
||||
$group->addUser($userC);
|
||||
|
||||
$savedExport = new SavedExport();
|
||||
$savedExport->setExportAlias('dummy_export');
|
||||
$savedExport->setUser($userA);
|
||||
|
||||
foreach ($alls as $attribute) {
|
||||
yield [
|
||||
$attribute,
|
||||
$savedExport,
|
||||
$userA,
|
||||
VoterInterface::ACCESS_GRANTED,
|
||||
true,
|
||||
];
|
||||
}
|
||||
|
||||
yield [
|
||||
SavedExportVoter::GENERATE,
|
||||
$savedExport,
|
||||
$userA,
|
||||
VoterInterface::ACCESS_DENIED,
|
||||
false,
|
||||
];
|
||||
|
||||
foreach ($alls as $attribute) {
|
||||
yield [
|
||||
$attribute,
|
||||
$savedExport,
|
||||
$userB,
|
||||
VoterInterface::ACCESS_DENIED,
|
||||
true,
|
||||
];
|
||||
}
|
||||
|
||||
$savedExport = new SavedExport();
|
||||
$savedExport->setExportAlias('dummy_export');
|
||||
$savedExport->setUser($userA);
|
||||
$savedExport->addShare($userB);
|
||||
|
||||
yield [
|
||||
SavedExportVoter::GENERATE,
|
||||
$savedExport,
|
||||
$userB,
|
||||
VoterInterface::ACCESS_DENIED,
|
||||
false,
|
||||
];
|
||||
|
||||
yield [
|
||||
SavedExportVoter::GENERATE,
|
||||
$savedExport,
|
||||
$userB,
|
||||
VoterInterface::ACCESS_GRANTED,
|
||||
true,
|
||||
];
|
||||
|
||||
foreach ([SavedExportVoter::EDIT, SavedExportVoter::DELETE] as $attribute) {
|
||||
yield [
|
||||
$attribute,
|
||||
$savedExport,
|
||||
$userB,
|
||||
VoterInterface::ACCESS_DENIED,
|
||||
true,
|
||||
];
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user