Commit 057c07ba authored by Steve Müller's avatar Steve Müller

Merge pull request #723 from digilist/master

Quote the name of an index in the create table statement.
parents ea293e39 6be3dcb3
......@@ -1517,7 +1517,7 @@ abstract class AbstractPlatform
$options['primary'] = $index->getQuotedColumns($this);
$options['primary_index'] = $index;
} else {
$options['indexes'][$index->getName()] = $index;
$options['indexes'][$index->getQuotedName($this)] = $index;
}
}
}
......
......@@ -242,6 +242,13 @@ abstract class AbstractMySQLPlatformTestCase extends AbstractPlatformTestCase
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 VARCHAR(255) NOT NULL, INDEX `key` (column1)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB'
);
}
protected function getQuotedColumnInForeignKeySQL()
{
return array(
......
......@@ -539,6 +539,7 @@ abstract class AbstractPlatformTestCase extends \Doctrine\Tests\DbalTestCase
abstract protected function getQuotedColumnInPrimaryKeySQL();
abstract protected function getQuotedColumnInIndexSQL();
abstract protected function getQuotedNameInIndexSQL();
abstract protected function getQuotedColumnInForeignKeySQL();
/**
......@@ -554,6 +555,16 @@ abstract class AbstractPlatformTestCase extends \Doctrine\Tests\DbalTestCase
$this->assertEquals($this->getQuotedColumnInIndexSQL(), $sql);
}
public function testQuotedNameInIndexSQL()
{
$table = new Table('test');
$table->addColumn('column1', 'string');
$table->addIndex(array('column1'), '`key`');
$sql = $this->_platform->getCreateTableSQL($table);
$this->assertEquals($this->getQuotedNameInIndexSQL(), $sql);
}
/**
* @group DBAL-374
*/
......
......@@ -280,6 +280,14 @@ abstract class AbstractPostgreSqlPlatformTestCase extends AbstractPlatformTestCa
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 VARCHAR(255) NOT NULL)',
'CREATE INDEX "key" ON test (column1)',
);
}
protected function getQuotedColumnInForeignKeySQL()
{
return array(
......
......@@ -455,6 +455,14 @@ abstract class AbstractSQLServerPlatformTestCase extends AbstractPlatformTestCas
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 NVARCHAR(255) NOT NULL)',
'CREATE INDEX [key] ON test (column1)',
);
}
protected function getQuotedColumnInForeignKeySQL()
{
return array(
......
......@@ -86,6 +86,14 @@ class DB2PlatformTest extends AbstractPlatformTestCase
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 VARCHAR(255) NOT NULL)',
'CREATE INDEX "key" ON test (column1)',
);
}
protected function getQuotedColumnInPrimaryKeySQL()
{
return array(
......
......@@ -344,6 +344,14 @@ class OraclePlatformTest extends AbstractPlatformTestCase
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 VARCHAR2(255) NOT NULL)',
'CREATE INDEX "key" ON test (column1)',
);
}
protected function getQuotedColumnInForeignKeySQL()
{
return array(
......
......@@ -78,6 +78,14 @@ class SQLAnywherePlatformTest extends AbstractPlatformTestCase
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 VARCHAR(255) NOT NULL)',
'CREATE INDEX "key" ON test (column1)',
);
}
protected function getQuotedColumnInPrimaryKeySQL()
{
return array(
......
......@@ -440,6 +440,14 @@ class SqlitePlatformTest extends AbstractPlatformTestCase
);
}
protected function getQuotedNameInIndexSQL()
{
return array(
'CREATE TABLE test (column1 VARCHAR(255) NOT NULL)',
'CREATE INDEX "key" ON test (column1)',
);
}
protected function getQuotedColumnInForeignKeySQL()
{
return array(
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment