mirror of
https://github.com/MarijnDoeve/TijdVoorDeTest.git
synced 2026-03-06 04:44:19 +01:00
112 lines
3.6 KiB
PHP
112 lines
3.6 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Tvdt\Tests\Security\Voter;
|
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
use PHPUnit\Framework\MockObject\Stub;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
|
|
use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
|
|
use Symfony\Component\Security\Core\User\UserInterface;
|
|
use Tvdt\Entity\Answer;
|
|
use Tvdt\Entity\Candidate;
|
|
use Tvdt\Entity\Elimination;
|
|
use Tvdt\Entity\Question;
|
|
use Tvdt\Entity\Quiz;
|
|
use Tvdt\Entity\Season;
|
|
use Tvdt\Entity\User;
|
|
use Tvdt\Security\Voter\SeasonVoter;
|
|
|
|
#[CoversClass(SeasonVoter::class)]
|
|
final class SeasonVoterTest extends TestCase
|
|
{
|
|
private SeasonVoter $seasonVoter;
|
|
|
|
private TokenInterface&Stub $token;
|
|
|
|
protected function setUp(): void
|
|
{
|
|
$this->seasonVoter = new SeasonVoter();
|
|
$this->token = $this->createStub(TokenInterface::class);
|
|
|
|
$user = $this->createStub(User::class);
|
|
$this->token->method('getUser')->willReturn($user);
|
|
}
|
|
|
|
#[DataProvider('typesProvider')]
|
|
public function testWithTypes(mixed $subject): void
|
|
{
|
|
$this->assertSame(VoterInterface::ACCESS_GRANTED, $this->seasonVoter->vote($this->token, $subject, ['SEASON_EDIT']));
|
|
}
|
|
|
|
public function testNotOwnerWillReturnDenied(): void
|
|
{
|
|
$season = self::createStub(Season::class);
|
|
$season->method('isOwner')->willReturn(false);
|
|
|
|
$this->assertSame(VoterInterface::ACCESS_DENIED, $this->seasonVoter->vote($this->token, $season, ['SEASON_EDIT']));
|
|
}
|
|
|
|
public static function typesProvider(): \Generator
|
|
{
|
|
$season = self::createStub(Season::class);
|
|
$season->method('isOwner')->willReturn(true);
|
|
yield 'Season' => [$season];
|
|
|
|
$candidate = self::createStub(Candidate::class);
|
|
$candidate->season = $season;
|
|
yield 'Candidate' => [$candidate];
|
|
|
|
$quiz = self::createStub(Quiz::class);
|
|
$quiz->season = $season;
|
|
yield 'Quiz' => [$quiz];
|
|
|
|
$elimination = self::createStub(Elimination::class);
|
|
$elimination->quiz = $quiz;
|
|
yield 'Elimination' => [$elimination];
|
|
|
|
$question = self::createStub(Question::class);
|
|
$question->quiz = $quiz;
|
|
yield 'Question' => [$question];
|
|
|
|
$answer = self::createStub(Answer::class);
|
|
$answer->question = $question;
|
|
yield 'Answer' => [$answer];
|
|
}
|
|
|
|
public function testWrongUserTypeReturnFalse(): void
|
|
{
|
|
$user = self::createStub(UserInterface::class);
|
|
$token = $this->createStub(TokenInterface::class);
|
|
$token->method('getUser')->willReturn($user);
|
|
|
|
$this->assertSame(VoterInterface::ACCESS_DENIED, $this->seasonVoter->vote($token, new Season(), ['SEASON_EDIT']));
|
|
}
|
|
|
|
public function testAdminCanDoAnything(): void
|
|
{
|
|
$user = new User();
|
|
$user->roles = ['ROLE_ADMIN'];
|
|
|
|
$token = $this->createStub(TokenInterface::class);
|
|
$token->method('getUser')->willReturn($user);
|
|
|
|
$this->assertSame(VoterInterface::ACCESS_GRANTED, $this->seasonVoter->vote($token, new Season(), ['SEASON_EDIT']));
|
|
}
|
|
|
|
public function testRandomClassWillAbstain(): void
|
|
{
|
|
$subject = new \stdClass();
|
|
$this->assertSame(VoterInterface::ACCESS_ABSTAIN, $this->seasonVoter->vote($this->token, $subject, ['SEASON_EDIT']));
|
|
}
|
|
|
|
public function testRandomSunjectWillAbstain(): void
|
|
{
|
|
$subject = new Season();
|
|
$this->assertSame(VoterInterface::ACCESS_ABSTAIN, $this->seasonVoter->vote($this->token, $subject, ['DO_NOTHING']));
|
|
}
|
|
}
|