mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-01-10 19:47:35 +00:00
133 lines
4.7 KiB
PHP
133 lines
4.7 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Kimai time-tracking app.
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace App\Tests\Voter;
|
|
|
|
use App\Entity\Activity;
|
|
use App\Entity\User;
|
|
use App\Voter\RolePermissionVoter;
|
|
use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
|
|
use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
|
|
|
|
/**
|
|
* @covers \App\Voter\RolePermissionVoter
|
|
*/
|
|
class RolePermissionVoterTest extends AbstractVoterTestCase
|
|
{
|
|
/**
|
|
* @dataProvider getTestData
|
|
*/
|
|
public function testVote(User $user, $subject, $attribute, $result): void
|
|
{
|
|
$token = new UsernamePasswordToken($user, 'bar', $user->getRoles());
|
|
$sut = $this->getVoter(RolePermissionVoter::class);
|
|
|
|
$actual = $sut->vote($token, $subject, [$attribute]);
|
|
self::assertEquals($result, $actual, \sprintf('Failed voting "%s" for User with roles %s.', $attribute, implode(', ', $user->getRoles())));
|
|
}
|
|
|
|
public static function getTestData()
|
|
{
|
|
$userNoRole = self::getUser(0, 'foo');
|
|
$userStandard = self::getUser(1, User::ROLE_USER);
|
|
$userTeamlead = self::getUser(2, User::ROLE_TEAMLEAD);
|
|
$userAdmin = self::getUser(3, User::ROLE_ADMIN);
|
|
$userSuperAdmin = self::getUser(4, User::ROLE_SUPER_ADMIN);
|
|
|
|
$invoice = [
|
|
'manage_invoice_template' => null,
|
|
'view_invoice' => null,
|
|
'create_invoice' => null,
|
|
];
|
|
|
|
$timesheet = [
|
|
'view_own_timesheet' => null,
|
|
'create_own_timesheet' => null,
|
|
'export_own_timesheet' => null,
|
|
];
|
|
|
|
$timesheetOther = [
|
|
'view_other_timesheet' => null,
|
|
'create_other_timesheet' => null,
|
|
];
|
|
|
|
$others = [
|
|
'create_customer' => null,
|
|
'create_project' => null,
|
|
];
|
|
|
|
$users = [
|
|
'create_user' => null,
|
|
'view_user' => null,
|
|
];
|
|
|
|
// ================== GRANTED ==================
|
|
$result = VoterInterface::ACCESS_GRANTED;
|
|
|
|
$entries = array_merge($timesheet);
|
|
foreach ([$userNoRole, $userStandard, $userTeamlead, $userAdmin, $userSuperAdmin] as $user) {
|
|
foreach ($entries as $permission => $entity) {
|
|
yield [$user, $entity, $permission, $result];
|
|
yield [$user, null, $permission, $result];
|
|
}
|
|
}
|
|
|
|
$entriesAdmin = array_merge($others, $timesheetOther, $invoice, $timesheet);
|
|
foreach ([$userAdmin, $userSuperAdmin] as $user) {
|
|
foreach ($entriesAdmin as $permission => $entity) {
|
|
yield [$user, $entity, $permission, $result];
|
|
yield [$user, null, $permission, $result];
|
|
}
|
|
}
|
|
|
|
$entriesSuperAdmin = array_merge($users);
|
|
foreach ($entriesSuperAdmin as $permission => $entity) {
|
|
yield [$userSuperAdmin, $entity, $permission, $result];
|
|
yield [$userSuperAdmin, null, $permission, $result];
|
|
}
|
|
|
|
// ================== DENIED ==================
|
|
// this test might fail in the future due to the role permissions
|
|
$result = VoterInterface::ACCESS_DENIED;
|
|
|
|
foreach ([$userNoRole, $userStandard, $userTeamlead] as $user) {
|
|
foreach ($others as $permission => $entity) {
|
|
yield [$user, $entity, $permission, $result];
|
|
}
|
|
}
|
|
foreach ([$userNoRole, $userStandard] as $user) {
|
|
foreach (['view_activity' => null] as $permission => $entity) {
|
|
yield [$user, $entity, $permission, $result];
|
|
}
|
|
}
|
|
foreach ([$userNoRole, $userStandard] as $user) {
|
|
foreach ($invoice as $permission => $entity) {
|
|
yield [$user, $entity, $permission, $result];
|
|
}
|
|
}
|
|
foreach ([$userNoRole, $userStandard] as $user) {
|
|
foreach ($timesheetOther as $permission => $entity) {
|
|
yield [$user, $entity, $permission, $result];
|
|
}
|
|
}
|
|
|
|
// ================== ABSTAIN ==================
|
|
$result = VoterInterface::ACCESS_ABSTAIN;
|
|
foreach ([$userAdmin, $userSuperAdmin] as $user) {
|
|
yield [$user, new Activity(), 'view', $result];
|
|
yield [$user, new Activity(), 'edit', $result];
|
|
yield [$user, new Activity(), 'delete', $result];
|
|
yield [$user, new Activity(), 'ROLE_USER', $result];
|
|
yield [$user, new Activity(), 'ROLE_ADMIN', $result];
|
|
yield [$user, new \stdClass(), 'view', $result];
|
|
yield [$user, null, 'edit', $result];
|
|
yield [$user, $user, 'delete', $result];
|
|
}
|
|
}
|
|
}
|