wiki.techinc.nl/tests/phpunit/unit/includes/libs/rdbms/database/DoctrineSchemaBuilderTest.php
Reedy c14dd609a7 tests: Move Wikimedia tests into Wikimedia\Tests
Change-Id: I9c64a631b0b4e8e4fef8a72ee0f749d35f918052
2024-02-17 02:09:08 +00:00

56 lines
1.5 KiB
PHP

<?php
namespace Wikimedia\Tests\Rdbms;
use Doctrine\DBAL\Platforms\AbstractPlatform;
use Doctrine\DBAL\Platforms\SqlitePlatform;
use MediaWikiUnitTestCase;
use Wikimedia\Rdbms\DoctrineSchemaBuilder;
use Wikimedia\Rdbms\MWMySQLPlatform;
use Wikimedia\Rdbms\MWPostgreSqlPlatform;
class DoctrineSchemaBuilderTest extends MediaWikiUnitTestCase {
/**
* @dataProvider provideTestGetResultAllTables
* @covers \Wikimedia\Rdbms\DoctrineSchemaBuilder
*
* @param AbstractPlatform $platform
* @param string $expectedFile path fragment
*/
public function testGetResultAllTables( $platform, $expectedFile ) {
$basePath = dirname( __DIR__, 5 );
$builder = new DoctrineSchemaBuilder( $platform );
$json = file_get_contents( $basePath . '/data/db/tables.json' );
$tables = json_decode( $json, true );
foreach ( $tables as $table ) {
$builder->addTable( $table );
}
$actual = implode( "\n", $builder->getSql() );
$actual = preg_replace( "/\s*?(\n|$)/m", "", $actual );
$expected = file_get_contents( $basePath . $expectedFile );
$expected = preg_replace( "/\s*?(\n|$)/m", "", $expected );
$this->assertSame( $expected, $actual );
}
public static function provideTestGetResultAllTables() {
yield 'MySQL schema tables' => [
new MWMySQLPlatform,
'/data/db/mysql/tables.sql',
];
yield 'PostgreSQL schema tables' => [
new MWPostgreSqlPlatform,
'/data/db/postgres/tables.sql'
];
yield 'SQLite schema tables' => [
new SqlitePlatform,
'/data/db/sqlite/tables.sql'
];
}
}