2009-12-02 18:52:21 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\DBAL\Platforms;
|
|
|
|
|
|
|
|
abstract class AbstractPlatformTestCase extends \Doctrine\Tests\DbalTestCase
|
|
|
|
{
|
2010-01-20 22:35:18 +00:00
|
|
|
/**
|
|
|
|
* @var Doctrine\DBAL\Platforms\AbstractPlatform
|
|
|
|
*/
|
2009-12-02 18:52:21 +00:00
|
|
|
protected $_platform;
|
|
|
|
|
|
|
|
abstract public function createPlatform();
|
|
|
|
|
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
$this->_platform = $this->createPlatform();
|
|
|
|
}
|
|
|
|
|
2010-02-19 22:33:54 +00:00
|
|
|
public function testCreateWithNoColumns()
|
|
|
|
{
|
|
|
|
$table = new \Doctrine\DBAL\Schema\Table('test');
|
|
|
|
|
|
|
|
$this->setExpectedException('Doctrine\DBAL\DBALException');
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateTableSQL($table);
|
2010-02-19 22:33:54 +00:00
|
|
|
}
|
|
|
|
|
2009-12-02 18:52:21 +00:00
|
|
|
public function testGeneratesTableCreationSql()
|
|
|
|
{
|
|
|
|
$table = new \Doctrine\DBAL\Schema\Table('test');
|
2010-02-25 21:51:30 +00:00
|
|
|
$table->addColumn('id', 'integer', array('notnull' => true));
|
|
|
|
$table->addColumn('test', 'string', array('notnull' => false, 'length' => 255));
|
2009-12-02 18:52:21 +00:00
|
|
|
$table->setPrimaryKey(array('id'));
|
|
|
|
$table->setIdGeneratorType(\Doctrine\DBAL\Schema\Table::ID_IDENTITY);
|
|
|
|
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateTableSQL($table);
|
2009-12-02 18:52:21 +00:00
|
|
|
$this->assertEquals($this->getGenerateTableSql(), $sql[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract public function getGenerateTableSql();
|
|
|
|
|
2009-12-10 23:55:47 +00:00
|
|
|
public function testGenerateTableWithMultiColumnUniqueIndex()
|
|
|
|
{
|
|
|
|
$table = new \Doctrine\DBAL\Schema\Table('test');
|
2010-02-25 21:51:30 +00:00
|
|
|
$table->addColumn('foo', 'string', array('notnull' => false, 'length' => 255));
|
|
|
|
$table->addColumn('bar', 'string', array('notnull' => false, 'length' => 255));
|
2009-12-10 23:55:47 +00:00
|
|
|
$table->addUniqueIndex(array("foo", "bar"));
|
|
|
|
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateTableSQL($table);
|
2009-12-10 23:55:47 +00:00
|
|
|
$this->assertEquals($this->getGenerateTableWithMultiColumnUniqueIndexSql(), $sql);
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract public function getGenerateTableWithMultiColumnUniqueIndexSql();
|
|
|
|
|
2009-12-02 18:52:21 +00:00
|
|
|
public function testGeneratesIndexCreationSql()
|
|
|
|
{
|
|
|
|
$indexDef = new \Doctrine\DBAL\Schema\Index('my_idx', array('user_name', 'last_login'));
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
$this->getGenerateIndexSql(),
|
2010-03-05 16:35:00 +00:00
|
|
|
$this->_platform->getCreateIndexSQL($indexDef, 'mytable')
|
2009-12-02 18:52:21 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract public function getGenerateIndexSql();
|
|
|
|
|
|
|
|
public function testGeneratesUniqueIndexCreationSql()
|
|
|
|
{
|
|
|
|
$indexDef = new \Doctrine\DBAL\Schema\Index('index_name', array('test', 'test2'), true);
|
|
|
|
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateIndexSQL($indexDef, 'test');
|
2009-12-02 18:52:21 +00:00
|
|
|
$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'), '');
|
|
|
|
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateForeignKeySQL($fk, 'test');
|
2009-12-02 18:52:21 +00:00
|
|
|
$this->assertEquals($sql, $this->getGenerateForeignKeySql());
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract public function getGenerateForeignKeySql();
|
2009-12-02 22:28:38 +00:00
|
|
|
|
|
|
|
public function testGeneratesConstraintCreationSql()
|
|
|
|
{
|
|
|
|
$idx = new \Doctrine\DBAL\Schema\Index('constraint_name', array('test'), true, false);
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateConstraintSQL($idx, 'test');
|
2009-12-02 22:28:38 +00:00
|
|
|
$this->assertEquals($this->getGenerateConstraintUniqueIndexSql(), $sql);
|
|
|
|
|
|
|
|
$pk = new \Doctrine\DBAL\Schema\Index('constraint_name', array('test'), true, true);
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateConstraintSQL($pk, 'test');
|
2009-12-02 22:28:38 +00:00
|
|
|
$this->assertEquals($this->getGenerateConstraintPrimaryIndexSql(), $sql);
|
|
|
|
|
|
|
|
$fk = new \Doctrine\DBAL\Schema\ForeignKeyConstraint(array('fk_name'), 'foreign', array('id'), 'constraint_fk');
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getCreateConstraintSQL($fk, 'test');
|
2009-12-02 22:28:38 +00:00
|
|
|
$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)';
|
|
|
|
}
|
2009-12-05 23:06:29 +00:00
|
|
|
|
|
|
|
abstract public function getGenerateAlterTableSql();
|
|
|
|
|
2009-12-06 12:13:15 +00:00
|
|
|
public function testGeneratesTableAlterationSql()
|
2009-12-05 23:06:29 +00:00
|
|
|
{
|
|
|
|
$expectedSql = $this->getGenerateAlterTableSql();
|
|
|
|
|
2009-12-06 12:13:15 +00:00
|
|
|
$columnDiff = new \Doctrine\DBAL\Schema\ColumnDiff(
|
|
|
|
'bar', new \Doctrine\DBAL\Schema\Column(
|
|
|
|
'baz', \Doctrine\DBAL\Types\Type::getType('string'), array('default' => 'def')
|
|
|
|
),
|
|
|
|
array('type', 'notnull', 'default')
|
|
|
|
);
|
|
|
|
|
2009-12-06 09:47:54 +00:00
|
|
|
$tableDiff = new \Doctrine\DBAL\Schema\TableDiff('mytable');
|
|
|
|
$tableDiff->newName = 'userlist';
|
|
|
|
$tableDiff->addedColumns['quota'] = new \Doctrine\DBAL\Schema\Column('quota', \Doctrine\DBAL\Types\Type::getType('integer'), array('notnull' => false));
|
2009-12-06 12:13:15 +00:00
|
|
|
$tableDiff->removedColumns['foo'] = new \Doctrine\DBAL\Schema\Column('foo', \Doctrine\DBAL\Types\Type::getType('integer'));
|
|
|
|
$tableDiff->changedColumns['bar'] = $columnDiff;
|
2009-12-06 09:47:54 +00:00
|
|
|
|
2010-03-05 16:35:00 +00:00
|
|
|
$sql = $this->_platform->getAlterTableSQL($tableDiff);
|
2009-12-06 09:47:54 +00:00
|
|
|
|
2009-12-06 12:13:15 +00:00
|
|
|
$this->assertEquals($expectedSql, $sql);
|
2009-12-05 23:06:29 +00:00
|
|
|
}
|
2010-01-20 22:35:18 +00:00
|
|
|
|
|
|
|
public function testGetCustomColumnDeclarationSql()
|
|
|
|
{
|
|
|
|
$field = array('columnDefinition' => 'MEDIUMINT(6) UNSIGNED');
|
2010-03-05 16:35:00 +00:00
|
|
|
$this->assertEquals('foo MEDIUMINT(6) UNSIGNED', $this->_platform->getColumnDeclarationSQL('foo', $field));
|
2010-01-20 22:35:18 +00:00
|
|
|
}
|
2009-12-02 18:52:21 +00:00
|
|
|
}
|