mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-01-26 17:58:54 +00:00
a636683dee
* added configurable activity number * added configurable project number * fix deprecations * added some tests for entity exporter * better configuration of dropdown pattern for customer, project and activity
61 lines
2.6 KiB
PHP
61 lines
2.6 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;
|
|
|
|
use App\Entity\Customer;
|
|
use App\Entity\Project;
|
|
use App\Export\Spreadsheet\AnnotatedObjectExporter;
|
|
use App\Export\Spreadsheet\Extractor\AnnotationExtractor;
|
|
use App\Export\Spreadsheet\SpreadsheetExporter;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
|
|
|
/**
|
|
* @covers \App\Export\Spreadsheet\AnnotatedObjectExporter
|
|
*/
|
|
class AnnotatedObjectExporterTest extends TestCase
|
|
{
|
|
public function testExport(): void
|
|
{
|
|
$spreadsheetExporter = new SpreadsheetExporter($this->createMock(TranslatorInterface::class));
|
|
$annotationExtractor = new AnnotationExtractor();
|
|
|
|
$project = new Project();
|
|
$project->setName('test project');
|
|
$project->setCustomer(new Customer('A customer'));
|
|
$project->setComment('Lorem Ipsum');
|
|
$project->setOrderNumber('1234567890');
|
|
$project->setBudget(123456.7890);
|
|
$project->setTimeBudget(1234567890);
|
|
$project->setBudgetType();
|
|
$project->setIsMonthlyBudget();
|
|
$project->setColor('#ababab');
|
|
$project->setVisible(false);
|
|
|
|
$sut = new AnnotatedObjectExporter($spreadsheetExporter, $annotationExtractor);
|
|
$spreadsheet = $sut->export(Project::class, [$project]);
|
|
$worksheet = $spreadsheet->getActiveSheet();
|
|
|
|
$i = 0;
|
|
self::assertNull($worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('test project', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('A customer', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals(1234567890, $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals(123456.7890, $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('=1234567890/86400', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('month', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('#ababab', $worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertFalse($worksheet->getCell([++$i, 2])->getValue());
|
|
self::assertEquals('Lorem Ipsum', $worksheet->getCell([++$i, 2])->getValue());
|
|
}
|
|
}
|