phpOMS/tests/DataStorage/Database/SchemaMapperTest.php
Dennis Eichhorn a1b591d141 fix tests
2024-03-20 03:00:25 +00:00

90 lines
3.0 KiB
PHP
Executable File

<?php
/**
* Jingga
*
* PHP Version 8.1
*
* @package tests
* @copyright Dennis Eichhorn
* @license OMS License 2.0
* @version 1.0.0
* @link https://jingga.app
*/
declare(strict_types=1);
namespace phpOMS\tests\DataStorage\Database;
use phpOMS\DataStorage\Database\SchemaMapper;
/**
* @testdox phpOMS\tests\DataStorage\Database\SchemaMapperTest: Mapper for the database schema
*
* @internal
*/
final class SchemaMapperTest extends \PHPUnit\Framework\TestCase
{
protected function setUp() : void
{
$GLOBALS['dbpool']->get()->con->prepare(
'CREATE TABLE `test_base` (
`test_base_id` int(11) NOT NULL AUTO_INCREMENT,
`test_base_string` varchar(254) NOT NULL,
`test_base_int` int(11) NOT NULL,
`test_base_bool` tinyint(1) DEFAULT NULL,
`test_base_null` int(11) DEFAULT NULL,
`test_base_float` decimal(5, 4) DEFAULT NULL,
`test_base_belongs_to_one` int(11) DEFAULT NULL,
`test_base_owns_one_self` int(11) DEFAULT NULL,
`test_base_json` varchar(254) DEFAULT NULL,
`test_base_json_serializable` varchar(254) DEFAULT NULL,
`test_base_serializable` varchar(254) DEFAULT NULL,
`test_base_datetime` datetime DEFAULT NULL,
`test_base_datetime_null` datetime DEFAULT NULL, /* There was a bug where it returned the current date because new \DateTime(null) === current date which is wrong, we want null as value! */
PRIMARY KEY (`test_base_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
)->execute();
$GLOBALS['dbpool']->get()->con->prepare(
'CREATE TABLE `test_belongs_to_one` (
`test_belongs_to_one_id` int(11) NOT NULL AUTO_INCREMENT,
`test_belongs_to_one_string` varchar(254) NOT NULL,
PRIMARY KEY (`test_belongs_to_one_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
)->execute();
}
protected function tearDown() : void
{
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_base')->execute();
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_belongs_to_one')->execute();
}
/**
* @testdox The tables can be returned
* @covers \phpOMS\DataStorage\Database\SchemaMapper
* @group framework
*/
public function testTables() : void
{
$schema = new SchemaMapper($GLOBALS['dbpool']->get());
self::assertTrue(\in_array('test_base', $schema->getTables()));
self::assertTrue(\in_array('test_belongs_to_one', $schema->getTables()));
}
/**
* @testdox The fields of a table can be returned
* @covers \phpOMS\DataStorage\Database\SchemaMapper
* @group framework
*/
public function testFields() : void
{
$schema = new SchemaMapper($GLOBALS['dbpool']->get());
self::assertEquals(
13,
\count($schema->getFields('test_base'))
);
}
}