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

115 lines
3.7 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\Schema\Grammar;
use phpOMS\DataStorage\Database\Connection\MysqlConnection;
use phpOMS\DataStorage\Database\Schema\Builder;
use phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar;
use phpOMS\Utils\ArrayUtils;
use phpOMS\Utils\TestUtils;
/**
* @testdox phpOMS\tests\DataStorage\Database\Schema\Grammar\MysqlGrammarTest: Mysql sql schema grammar
*
* @internal
*/
final class MysqlGrammarTest extends \PHPUnit\Framework\TestCase
{
protected MysqlConnection $con;
/**
* {@inheritdoc}
*/
protected function setUp() : void
{
$this->con = new MysqlConnection($GLOBALS['CONFIG']['db']['core']['masters']['admin']);
$this->con->connect();
}
/**
* @testdox The grammar has the expected default values after initialization
* @covers \phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar<extended>
* @group framework
*/
public function testDefault() : void
{
self::assertInstanceOf('\phpOMS\DataStorage\Database\Schema\Grammar\Grammar', new MysqlGrammar());
self::assertEquals('`', TestUtils::getMember(new MysqlGrammar(), 'systemIdentifierStart'));
self::assertEquals('`', TestUtils::getMember(new MysqlGrammar(), 'systemIdentifierEnd'));
}
/**
* @testdox The the grammar correctly creates and returns a database table
* @covers \phpOMS\DataStorage\Database\Schema\Builder
* @covers \phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar<extended>
* @group framework
*/
public function testSchemaInputOutput() : void
{
$definitions = \json_decode(\file_get_contents(__DIR__ . '/testSchema.json'), true);
foreach ($definitions as $definition) {
Builder::createFromSchema($definition, $this->con)->execute();
}
$table = new Builder($this->con);
$tables = $table->selectTables()->execute()->fetchAll(\PDO::FETCH_COLUMN);
self::assertContains('test', $tables);
self::assertContains('test_foreign', $tables);
$field = new Builder($this->con);
$fields = $field->selectFields('test')->execute()->fetchAll();
foreach ($definitions['test']['fields'] as $key => $field) {
self::assertTrue(
ArrayUtils::inArrayRecursive($key, $fields),
'Couldn\'t find "' . $key . '" in array'
);
}
$delete = new Builder($this->con);
$delete->dropTable('test')
->dropTable('test_foreign')
->execute();
}
/**
* @testdox The grammar correctly deletes a table
* @covers \phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar<extended>
* @group framework
*/
public function testDelete() : void
{
$definitions = \json_decode(\file_get_contents(__DIR__ . '/testSchema.json'), true);
foreach ($definitions as $definition) {
Builder::createFromSchema($definition, $this->con)->execute();
}
$table = new Builder($this->con);
$tables = $table->selectTables()->execute()->fetchAll(\PDO::FETCH_COLUMN);
self::assertContains('test', $tables);
self::assertContains('test_foreign', $tables);
$delete = new Builder($this->con);
$delete->dropTable('test')
->dropTable('test_foreign')
->execute();
$table = new Builder($this->con);
$tables = $table->selectTables()->execute()->fetchAll();
self::assertNotContains('test', $tables);
self::assertNotContains('test_foreign', $tables);
}
}