mirror of
https://github.com/Karaka-Management/oms-Script.git
synced 2026-01-11 12:28:41 +00:00
157 lines
5.5 KiB
PHP
Executable File
157 lines
5.5 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Jingga
|
|
*
|
|
* PHP Version 8.2
|
|
*
|
|
* @package tests
|
|
* @copyright Dennis Eichhorn
|
|
* @license OMS License 2.0
|
|
* @version 1.0.0
|
|
* @link https://jingga.app
|
|
*/
|
|
declare(strict_types=1);
|
|
|
|
namespace Modules\Script\tests\Models;
|
|
|
|
use Modules\Admin\Models\NullAccount;
|
|
use Modules\Media\Models\NullCollection;
|
|
use Modules\Script\Models\NullTemplate;
|
|
use Modules\Script\Models\Report;
|
|
use Modules\Script\Models\ScriptStatus;
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
#[\PHPUnit\Framework\Attributes\CoversClass(\Modules\Script\Models\Report::class)]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('Modules\tests\Helper\Models\ReportTest: Report model')]
|
|
final class ReportTest extends \PHPUnit\Framework\TestCase
|
|
{
|
|
protected Report $report;
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
protected function setUp() : void
|
|
{
|
|
$this->report = new Report();
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The model has the expected default values after initialization')]
|
|
public function testDefault() : void
|
|
{
|
|
self::assertEquals(0, $this->report->id);
|
|
self::assertEquals(0, $this->report->createdBy->id);
|
|
self::assertEquals((new \DateTime('now'))->format('Y-m-d'), $this->report->createdAt->format('Y-m-d'));
|
|
self::assertEquals('', $this->report->title);
|
|
self::assertEquals(ScriptStatus::INACTIVE, $this->report->status);
|
|
self::assertEquals('', $this->report->description);
|
|
self::assertEquals('', $this->report->descriptionRaw);
|
|
self::assertEquals(0, $this->report->template->id);
|
|
self::assertEquals(0, $this->report->source->id);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The creator can be set and returned correctly')]
|
|
public function testCreatedByInputOutput() : void
|
|
{
|
|
$this->report->createdBy = new NullAccount(1);
|
|
self::assertEquals(1, $this->report->createdBy->id);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The title can be set and returned correctly')]
|
|
public function testTitleInputOutput() : void
|
|
{
|
|
$this->report->title = 'Title';
|
|
self::assertEquals('Title', $this->report->title);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The description can be set and returned correctly')]
|
|
public function testDescriptionInputOutput() : void
|
|
{
|
|
$this->report->description = 'Description';
|
|
self::assertEquals('Description', $this->report->description);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The raw description can be set and returned correctly')]
|
|
public function testDescriptionRawInputOutput() : void
|
|
{
|
|
$this->report->descriptionRaw = 'DescriptionRaw';
|
|
self::assertEquals('DescriptionRaw', $this->report->descriptionRaw);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The template can be set and returned correctly')]
|
|
public function testTemplateInputOutput() : void
|
|
{
|
|
$this->report->template = new NullTemplate(11);
|
|
self::assertEquals(11, $this->report->template->id);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('The source can be set and returned correctly')]
|
|
public function testSourceInputOutput() : void
|
|
{
|
|
$this->report->source = new NullCollection(4);
|
|
self::assertEquals(4, $this->report->source->id);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('Report data can be turned into an array')]
|
|
public function testToArray() : void
|
|
{
|
|
$this->report->template = new NullTemplate(11);
|
|
$this->report->title = 'testTitle';
|
|
$this->report->description = 'testDescription';
|
|
$this->report->descriptionRaw = 'testDescriptionRaw';
|
|
|
|
$array = $this->report->toArray();
|
|
$expected = [
|
|
'id' => 0,
|
|
'name' => 'testTitle',
|
|
'description' => 'testDescription',
|
|
'descriptionRaw' => 'testDescriptionRaw',
|
|
'status' => ScriptStatus::INACTIVE,
|
|
];
|
|
|
|
foreach ($expected as $key => $e) {
|
|
if (!isset($array[$key]) || $array[$key] !== $e) {
|
|
self::assertTrue(false);
|
|
}
|
|
}
|
|
|
|
self::assertTrue(true);
|
|
}
|
|
|
|
#[\PHPUnit\Framework\Attributes\Group('module')]
|
|
#[\PHPUnit\Framework\Attributes\TestDox('Report data can be json serialized')]
|
|
public function testJsonSerialize() : void
|
|
{
|
|
$this->report->template = new NullTemplate(11);
|
|
$this->report->title = 'testTitle';
|
|
$this->report->description = 'testDescription';
|
|
$this->report->descriptionRaw = 'testDescriptionRaw';
|
|
|
|
$array = $this->report->jsonSerialize();
|
|
$expected = [
|
|
'id' => 0,
|
|
'name' => 'testTitle',
|
|
'description' => 'testDescription',
|
|
'descriptionRaw' => 'testDescriptionRaw',
|
|
'status' => ScriptStatus::INACTIVE,
|
|
];
|
|
|
|
foreach ($expected as $key => $e) {
|
|
if (!isset($array[$key]) || $array[$key] !== $e) {
|
|
self::assertTrue(false);
|
|
}
|
|
}
|
|
|
|
self::assertTrue(true);
|
|
}
|
|
}
|