115 lines
4.1 KiB
PHP
115 lines
4.1 KiB
PHP
<?php
|
|
|
|
namespace Doctrine\Tests\DBAL\Platforms;
|
|
|
|
abstract class AbstractPlatformTestCase extends \Doctrine\Tests\DbalTestCase
|
|
{
|
|
protected $_platform;
|
|
|
|
abstract public function createPlatform();
|
|
|
|
public function setUp()
|
|
{
|
|
$this->_platform = $this->createPlatform();
|
|
}
|
|
|
|
public function testGeneratesTableCreationSql()
|
|
{
|
|
$table = new \Doctrine\DBAL\Schema\Table('test');
|
|
$table->createColumn('id', 'integer', array('notnull' => true));
|
|
$table->createColumn('test', 'string', array('notnull' => false, 'length' => 255));
|
|
$table->setPrimaryKey(array('id'));
|
|
$table->setIdGeneratorType(\Doctrine\DBAL\Schema\Table::ID_IDENTITY);
|
|
|
|
$sql = $this->_platform->getCreateTableSql($table);
|
|
$this->assertEquals($this->getGenerateTableSql(), $sql[0]);
|
|
}
|
|
|
|
abstract public function getGenerateTableSql();
|
|
|
|
public function testGeneratesIndexCreationSql()
|
|
{
|
|
$indexDef = new \Doctrine\DBAL\Schema\Index('my_idx', array('user_name', 'last_login'));
|
|
|
|
$this->assertEquals(
|
|
$this->getGenerateIndexSql(),
|
|
$this->_platform->getCreateIndexSql($indexDef, 'mytable')
|
|
);
|
|
}
|
|
|
|
abstract public function getGenerateIndexSql();
|
|
|
|
public function testGeneratesUniqueIndexCreationSql()
|
|
{
|
|
$indexDef = new \Doctrine\DBAL\Schema\Index('index_name', array('test', 'test2'), true);
|
|
|
|
$sql = $this->_platform->getCreateIndexSql($indexDef, 'test');
|
|
$this->assertEquals($this->getGenerateUniqueIndexSql(), $sql);
|
|
}
|
|
|
|
abstract public function getGenerateUniqueIndexSql();
|
|
|
|
public function testGeneratesForeignKeyCreationSql()
|
|
{
|
|
$fk = new \Doctrine\DBAL\Schema\ForeignKeyConstraint(array('fk_name_id'), 'other_table', array('id'), '');
|
|
|
|
$sql = $this->_platform->getCreateForeignKeySql($fk, 'test');
|
|
$this->assertEquals($sql, $this->getGenerateForeignKeySql());
|
|
}
|
|
|
|
abstract public function getGenerateForeignKeySql();
|
|
|
|
public function testGeneratesConstraintCreationSql()
|
|
{
|
|
$idx = new \Doctrine\DBAL\Schema\Index('constraint_name', array('test'), true, false);
|
|
$sql = $this->_platform->getCreateConstraintSql($idx, 'test');
|
|
$this->assertEquals($this->getGenerateConstraintUniqueIndexSql(), $sql);
|
|
|
|
$pk = new \Doctrine\DBAL\Schema\Index('constraint_name', array('test'), true, true);
|
|
$sql = $this->_platform->getCreateConstraintSql($pk, 'test');
|
|
$this->assertEquals($this->getGenerateConstraintPrimaryIndexSql(), $sql);
|
|
|
|
$fk = new \Doctrine\DBAL\Schema\ForeignKeyConstraint(array('fk_name'), 'foreign', array('id'), 'constraint_fk');
|
|
$sql = $this->_platform->getCreateConstraintSql($fk, 'test');
|
|
$this->assertEquals($this->getGenerateConstraintForeignKeySql(), $sql);
|
|
}
|
|
|
|
public function getGenerateConstraintUniqueIndexSql()
|
|
{
|
|
return 'ALTER TABLE test ADD CONSTRAINT constraint_name UNIQUE (test)';
|
|
}
|
|
|
|
public function getGenerateConstraintPrimaryIndexSql()
|
|
{
|
|
return 'ALTER TABLE test ADD CONSTRAINT constraint_name PRIMARY KEY (test)';
|
|
}
|
|
|
|
public function getGenerateConstraintForeignKeySql()
|
|
{
|
|
return 'ALTER TABLE test ADD CONSTRAINT constraint_fk FOREIGN KEY (fk_name) REFERENCES foreign (id)';
|
|
}
|
|
|
|
abstract public function getGenerateAlterTableSql();
|
|
|
|
public function testGeneratesTableAlterationSqlForAddingAndRenaming()
|
|
{
|
|
$expectedSql = $this->getGenerateAlterTableSql();
|
|
|
|
$changes = array(
|
|
'name' => 'userlist',
|
|
'add' => array(
|
|
'quota' => array(
|
|
'type' => \Doctrine\DBAL\Types\Type::getType('integer'),
|
|
'notnull' => false,
|
|
)
|
|
));
|
|
|
|
$sql = $this->_platform->getAlterTableSql('mytable', $changes);
|
|
|
|
$this->assertEquals(count($sql), count($expectedSql), "Expecting the same number of sql queries for alter table failed.");
|
|
for ($i = 0; $i < count($expectedSql); $i++) {
|
|
$this->assertEquals($expectedSql[$i], $sql[$i], $i."th query of alter table does not match.");
|
|
}
|
|
}
|
|
}
|