mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-04-19 11:39:48 +00:00

* bump packages * dynamic invoice options * make sure that invoice previews can be detected * support for mpdf associated files * do not include any future times in work contract calculation * re-add username column in Excel spreadsheet * deactivate internal rate editing * show if plugin update exists * shorten name to Kimai only, without Time-Tracking * remove check for existing id in work contract * fix metafield already defined in search * helper methods to unlock months * new translation * send event on unlock month
42 lines
1.5 KiB
PHP
42 lines
1.5 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\EventSubscriber\Actions;
|
|
|
|
use App\EventSubscriber\Actions\AbstractActionsSubscriber;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
|
|
use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
|
|
|
|
/**
|
|
* @covers \App\EventSubscriber\Actions\AbstractActionsSubscriber
|
|
*/
|
|
abstract class AbstractActionsSubscriberTestCase extends TestCase
|
|
{
|
|
protected function createSubscriber(string $className, ...$grants): AbstractActionsSubscriber
|
|
{
|
|
$auth = $this->createMock(AuthorizationCheckerInterface::class);
|
|
$auth->method('isGranted')->willReturnOnConsecutiveCalls(...$grants); // @phpstan-ignore argument.named
|
|
$router = $this->createMock(UrlGeneratorInterface::class);
|
|
$router->method('generate')->willReturnArgument(0);
|
|
|
|
return new $className($auth, $router);
|
|
}
|
|
|
|
public function assertGetSubscribedEvent(string $className, string $name): void
|
|
{
|
|
self::assertTrue(method_exists($className, 'getSubscribedEvents'));
|
|
$events = $className::getSubscribedEvents();
|
|
$actionName = array_keys($events)[0];
|
|
$config = $events[$actionName];
|
|
self::assertEquals('actions.' . $name, $actionName);
|
|
self::assertTrue(method_exists($className, $config[0]));
|
|
self::assertEquals(1000, $config[1]);
|
|
}
|
|
}
|