mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-01-10 19:47:35 +00:00
143 lines
5.4 KiB
PHP
143 lines
5.4 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\Export\Spreadsheet\Extractor;
|
|
|
|
use App\Export\Spreadsheet\ColumnDefinition;
|
|
use App\Export\Spreadsheet\Extractor\AnnotationExtractor;
|
|
use App\Export\Spreadsheet\Extractor\ExtractorException;
|
|
use App\Tests\Export\Spreadsheet\Entities\DemoFull;
|
|
use App\Tests\Export\Spreadsheet\Entities\ExpressionOnMethod;
|
|
use App\Tests\Export\Spreadsheet\Entities\ExpressionOnProperty;
|
|
use App\Tests\Export\Spreadsheet\Entities\MethodRequiresParams;
|
|
use App\Tests\Export\Spreadsheet\Entities\MissingExpressionOnClass;
|
|
use App\Tests\Export\Spreadsheet\Entities\MissingNameOnClass;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
/**
|
|
* @covers \App\Export\Spreadsheet\Extractor\AnnotationExtractor
|
|
* @covers \App\Export\Annotation\Expose
|
|
* @covers \App\Export\Annotation\Order
|
|
* @covers \App\Export\Spreadsheet\Extractor\ExtractorException
|
|
*/
|
|
class AnnotationExtractorTest extends TestCase
|
|
{
|
|
public function testExtract(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$columns = $sut->extract(DemoFull::class);
|
|
|
|
self::assertIsArray($columns);
|
|
self::assertCount(10, $columns);
|
|
|
|
foreach ($columns as $column) {
|
|
self::assertInstanceOf(ColumnDefinition::class, $column);
|
|
}
|
|
|
|
$expected = [
|
|
['type-time', 'time', new \DateTime(), 'foo'],
|
|
['Public-Property', 'string', 'public-property', 'messages'],
|
|
['type-date', 'date', new \DateTime(), 'messages'],
|
|
['Private-Property', 'integer', 123, 'test'],
|
|
['accessor', 'string', 'accessor-method', 'messages'],
|
|
['Protected-Property', 'boolean', false, 'messages'],
|
|
['Public-Method', 'string', 'public-method', 'messages'],
|
|
['Protected-Method', 'datetime', new \DateTime(), 'messages'],
|
|
['duration', 'duration', 12345, 'messages'],
|
|
['Private-Method', 'boolean', true, 'bar'],
|
|
];
|
|
|
|
$i = 0;
|
|
$object = new DemoFull();
|
|
|
|
foreach ($expected as $item) {
|
|
$column = $columns[$i++];
|
|
self::assertEquals($item[0], $column->getLabel());
|
|
self::assertEquals($item[1], $column->getType());
|
|
$result = \call_user_func($column->getAccessor(), $object);
|
|
self::assertEquals(get_debug_type($item[2]), get_debug_type($result));
|
|
if (\in_array(get_debug_type($result), ['string', 'int', 'bool', 'float'])) {
|
|
self::assertEquals($item[2], $result);
|
|
}
|
|
self::assertEquals($item[3], $column->getTranslationDomain(), 'Failed translation domain for: ' . $item[0]);
|
|
}
|
|
}
|
|
|
|
public function testExceptionOnInvalidType(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('AnnotationExtractor needs a non-empty class name for work');
|
|
|
|
/* @phpstan-ignore argument.type */
|
|
$sut->extract(new \stdClass());
|
|
}
|
|
|
|
public function testExceptionOnEmptyString(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('AnnotationExtractor needs a non-empty class name for work');
|
|
|
|
$sut->extract('');
|
|
}
|
|
|
|
public function testExceptionOnMissingExpression(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('@Expose needs the "exp" attribute on class level hierarchy, check App\Tests\Export\Spreadsheet\Entities\MissingExpressionOnClass::class');
|
|
|
|
$sut->extract(MissingExpressionOnClass::class);
|
|
}
|
|
|
|
public function testExceptionOnMissingName(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('@Expose needs the "name" attribute on class level hierarchy, check App\Tests\Export\Spreadsheet\Entities\MissingNameOnClass::class');
|
|
|
|
$sut->extract(MissingNameOnClass::class);
|
|
}
|
|
|
|
public function testExceptionExpressionOnProperty(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('@Expose only supports the "exp" attribute on class level hierarchy, check App\Tests\Export\Spreadsheet\Entities\ExpressionOnProperty::$foo');
|
|
|
|
$sut->extract(ExpressionOnProperty::class);
|
|
}
|
|
|
|
public function testExceptionExpressionOnMethod(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('@Expose only supports the "exp" attribute on method level hierarchy, check App\Tests\Export\Spreadsheet\Entities\ExpressionOnMethod::foo()');
|
|
|
|
$sut->extract(ExpressionOnMethod::class);
|
|
}
|
|
|
|
public function testExceptionExpressionOnMethodWithRequiredParameters(): void
|
|
{
|
|
$sut = new AnnotationExtractor();
|
|
|
|
$this->expectException(ExtractorException::class);
|
|
$this->expectExceptionMessage('@Expose does not support method App\Tests\Export\Spreadsheet\Entities\MethodRequiresParams::foo(...) as it has required parameters.');
|
|
|
|
$sut->extract(MethodRequiresParams::class);
|
|
}
|
|
}
|