2009-10-31 22:23:36 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Tools\SchemaTool;
|
|
|
|
|
|
|
|
require_once __DIR__ . '/../../../TestInit.php';
|
|
|
|
|
|
|
|
class MysqlUpdateSchemaTest extends UpdateSchemaTestCase
|
|
|
|
{
|
|
|
|
protected function _createPlatform()
|
|
|
|
{
|
|
|
|
return new \Doctrine\DBAL\Platforms\MySqlPlatform();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddField()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestAddField();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals(
|
2009-11-02 12:53:05 +00:00
|
|
|
"ALTER TABLE cms_addresses ADD street VARCHAR(255) NOT NULL",
|
2009-10-31 22:23:36 +00:00
|
|
|
$sql[0]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testChangeColumnName()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeColumnName();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(2, count($sql));
|
|
|
|
$this->assertEquals("ALTER TABLE cms_addresses ADD the_city VARCHAR(50) NOT NULL", $sql[0]);
|
|
|
|
$this->assertEquals("ALTER TABLE cms_addresses DROP city", $sql[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testChangeNullability()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeNullability();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals("ALTER TABLE cms_addresses CHANGE city city VARCHAR(50) DEFAULT NULL", $sql[0]);
|
|
|
|
}
|
|
|
|
|
2009-11-02 12:53:05 +00:00
|
|
|
/**
|
|
|
|
* @group DDC-102
|
|
|
|
*/
|
|
|
|
public function testChangeNullabilityToNull()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeNullabilityToNull();
|
2009-11-02 12:53:05 +00:00
|
|
|
|
|
|
|
$this->assertEquals(0, count($sql));
|
|
|
|
}
|
|
|
|
|
2009-10-31 22:23:36 +00:00
|
|
|
public function testChangeType()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeType();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals("ALTER TABLE cms_addresses CHANGE city city TINYTEXT NOT NULL", $sql[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testChangeUniqueness()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeUniqueness();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals("ALTER TABLE cms_addresses CHANGE city city VARCHAR(50) NOT NULL UNIQUE", $sql[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testChangeLength()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeLength();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals('ALTER TABLE cms_addresses CHANGE city city VARCHAR(200) NOT NULL', $sql[0]);
|
|
|
|
}
|
|
|
|
|
2009-11-02 12:53:05 +00:00
|
|
|
/**
|
|
|
|
* @group DDC-101
|
|
|
|
*/
|
|
|
|
public function testChangeLengthToNull()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeLengthToNull();
|
2009-11-02 12:53:05 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals('ALTER TABLE cms_addresses CHANGE city city VARCHAR(255) NOT NULL', $sql[0]);
|
|
|
|
}
|
|
|
|
|
2009-10-31 22:23:36 +00:00
|
|
|
public function testChangeDecimalLengthPrecision()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeDecimalLengthPrecision();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
// invalid sql, because not escaped
|
|
|
|
$this->assertEquals('ALTER TABLE decimal_model CHANGE decimal decimal NUMERIC(10, 2) NOT NULL', $sql[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testChangeDecimalLengthScale()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeDecimalLengthScale();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
// invalid sql, because not escaped
|
|
|
|
$this->assertEquals('ALTER TABLE decimal_model CHANGE decimal decimal NUMERIC(5, 3) NOT NULL', $sql[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testChangeFixed()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestChangeFixed();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals(
|
|
|
|
"ALTER TABLE cms_addresses CHANGE city city CHAR(50) NOT NULL",
|
|
|
|
$sql[0]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddIndex()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestAddIndex();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals(
|
|
|
|
"CREATE INDEX searchCity (city)",
|
|
|
|
$sql[0]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRemoveField()
|
|
|
|
{
|
2009-11-02 16:07:31 +00:00
|
|
|
$sql = $this->_doTestRemoveField();
|
2009-10-31 22:23:36 +00:00
|
|
|
|
|
|
|
$this->assertEquals(1, count($sql));
|
|
|
|
$this->assertEquals(
|
|
|
|
"ALTER TABLE cms_addresses DROP city",
|
|
|
|
$sql[0]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|