mirror of
https://github.com/Karaka-Management/oms-Script.git
synced 2026-01-11 20:38:42 +00:00
184 lines
5.9 KiB
PHP
Executable File
184 lines
5.9 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Orange Management
|
|
*
|
|
* PHP Version 7.4
|
|
*
|
|
* @package tests
|
|
* @copyright Dennis Eichhorn
|
|
* @license OMS License 1.0
|
|
* @version 1.0.0
|
|
* @link https://orange-management.org
|
|
*/
|
|
declare(strict_types=1);
|
|
|
|
namespace Modules\Helper\tests\Models;
|
|
|
|
use Modules\Admin\Models\NullAccount;
|
|
use Modules\Helper\Models\HelperStatus;
|
|
use Modules\Helper\Models\Report;
|
|
use Modules\Helper\Models\ReportMapper;
|
|
use Modules\Helper\Models\Template;
|
|
use Modules\Helper\Models\TemplateDataType;
|
|
use Modules\Media\Models\Collection;
|
|
use Modules\Media\Models\Media;
|
|
|
|
/**
|
|
* @testdox Modules\tests\Helper\Models\ReportMapperTest: Report database mapper
|
|
*
|
|
* @internal
|
|
*/
|
|
class ReportMapperTest extends \PHPUnit\Framework\TestCase
|
|
{
|
|
private function createTemplate()
|
|
{
|
|
$template = new Template();
|
|
|
|
$template->setCreatedBy(new NullAccount(1));
|
|
$template->setName('Report Template');
|
|
$template->setStatus(HelperStatus::ACTIVE);
|
|
$template->setDescription('Description');
|
|
$template->setDatatype(TemplateDataType::OTHER);
|
|
$template->setStandalone(false);
|
|
$template->setExpected(['source1.csv', 'source2.csv']);
|
|
|
|
$collection = new Collection();
|
|
$collection->setCreatedBy(new NullAccount(1));
|
|
|
|
$templateFiles = [
|
|
[
|
|
'extension' => 'php',
|
|
'filename' => 'EventCourse.lang.php',
|
|
'name' => 'EventCourse',
|
|
'path' => '/Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'php',
|
|
'filename' => 'EventCourse.pdf.php',
|
|
'name' => 'EventCourse',
|
|
'path' => '/Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'php',
|
|
'filename' => 'EventCourse.tpl.php',
|
|
'name' => 'EventCourse',
|
|
'path' => '/Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'php',
|
|
'filename' => 'EventCourse.xlsx.php',
|
|
'name' => 'EventCourse',
|
|
'path' => '/Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'php',
|
|
'filename' => 'Worker.php',
|
|
'name' => 'Worker',
|
|
'path' => '/Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
];
|
|
|
|
foreach ($templateFiles as $file) {
|
|
$media = new Media();
|
|
$media->setCreatedBy(new NullAccount(1));
|
|
$media->setExtension($file['extension']);
|
|
$media->setPath(\trim($file['path'], '/') . '/' . $file['filename']);
|
|
$media->setName($file['name']);
|
|
$media->setSize($file['size']);
|
|
|
|
$collection->addSource($media);
|
|
}
|
|
|
|
$template->setSource($collection);
|
|
|
|
return $template;
|
|
}
|
|
|
|
/**
|
|
* @testdox The model can be created and read from the database
|
|
* @covers Modules\Helper\Models\ReportMapper
|
|
* @group module
|
|
*/
|
|
public function testCR() : void
|
|
{
|
|
$report = new Report();
|
|
|
|
$report->setCreatedBy(new NullAccount(1));
|
|
$report->setTitle('Title');
|
|
$report->setStatus(HelperStatus::ACTIVE);
|
|
$report->setDescription('Description');
|
|
$report->setTemplate($this->createTemplate());
|
|
|
|
$collection = new Collection();
|
|
$collection->setCreatedBy(new NullAccount(1));
|
|
|
|
$reportFiles = [
|
|
[
|
|
'extension' => 'csv',
|
|
'filename' => 'accounts.csv',
|
|
'name' => 'accounts',
|
|
'path' => 'Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'csv',
|
|
'filename' => 'costcenters.csv',
|
|
'name' => 'costcenters',
|
|
'path' => 'Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'csv',
|
|
'filename' => 'costobjects.csv',
|
|
'name' => 'costobjects',
|
|
'path' => 'Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'csv',
|
|
'filename' => 'crm.csv',
|
|
'name' => 'crm',
|
|
'path' => 'Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
[
|
|
'extension' => 'csv',
|
|
'filename' => 'entries.csv',
|
|
'name' => 'entries',
|
|
'path' => 'Demo/Modules/Helper/EventCourse',
|
|
'size' => 1,
|
|
],
|
|
];
|
|
|
|
foreach ($reportFiles as $file) {
|
|
$media = new Media();
|
|
$media->setCreatedBy(new NullAccount(1));
|
|
$media->setExtension($file['extension']);
|
|
$media->setPath(\trim($file['path'], '/') . '/' . $file['filename']);
|
|
$media->setName($file['name']);
|
|
$media->setSize($file['size']);
|
|
|
|
$collection->addSource($media);
|
|
}
|
|
|
|
$report->setSource($collection);
|
|
|
|
$id = ReportMapper::create($report);
|
|
self::assertGreaterThan(0, $report->getId());
|
|
self::assertEquals($id, $report->getId());
|
|
|
|
$reportR = ReportMapper::get($report->getId());
|
|
self::assertEquals($report->getCreatedAt()->format('Y-m-d'), $reportR->getCreatedAt()->format('Y-m-d'));
|
|
self::assertEquals($report->getCreatedBy()->getId(), $reportR->getCreatedBy()->getId());
|
|
self::assertEquals($report->getDescription(), $reportR->getDescription());
|
|
self::assertEquals($report->getTitle(), $reportR->getTitle());
|
|
self::assertEquals($report->getStatus(), $reportR->getStatus());
|
|
self::assertEquals($report->getTemplate()->getName(), $reportR->getTemplate()->getName());
|
|
}
|
|
}
|