_em->getConnection()->getDatabasePlatform()->getName() !== 'mysql') { $this->markTestSkipped('The ' . __CLASS__ .' requires the use of mysql.'); } } public function testGetCreateSchemaSql() { $classes = array( $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsAddress'), $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsUser'), $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsPhonenumber'), ); $tool = new SchemaTool($this->_em); $sql = $tool->getCreateSchemaSql($classes); $this->assertEquals(8, count($sql)); $this->assertEquals("CREATE TABLE cms_addresses (id INT AUTO_INCREMENT NOT NULL, country VARCHAR(50) NOT NULL, zip VARCHAR(50) NOT NULL, city VARCHAR(50) NOT NULL, user_id INT DEFAULT NULL, PRIMARY KEY(id)) ENGINE = InnoDB", $sql[0]); $this->assertEquals("CREATE TABLE cms_users (id INT AUTO_INCREMENT NOT NULL, status VARCHAR(50) NOT NULL, username VARCHAR(255) NOT NULL UNIQUE, name VARCHAR(255) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB", $sql[1]); $this->assertEquals("CREATE TABLE cms_users_groups (user_id INT DEFAULT NULL, group_id INT DEFAULT NULL, PRIMARY KEY(user_id, group_id)) ENGINE = InnoDB", $sql[2]); $this->assertEquals("CREATE TABLE cms_phonenumbers (phonenumber VARCHAR(50) NOT NULL, user_id INT DEFAULT NULL, PRIMARY KEY(phonenumber)) ENGINE = InnoDB", $sql[3]); $this->assertEquals("ALTER TABLE cms_addresses ADD FOREIGN KEY (user_id) REFERENCES cms_users(id)", $sql[4]); $this->assertEquals("ALTER TABLE cms_users_groups ADD FOREIGN KEY (user_id) REFERENCES cms_users(id)", $sql[5]); $this->assertEquals("ALTER TABLE cms_users_groups ADD FOREIGN KEY (group_id) REFERENCES cms_groups(id)", $sql[6]); $this->assertEquals("ALTER TABLE cms_phonenumbers ADD FOREIGN KEY (user_id) REFERENCES cms_users(id)", $sql[7]); } public function testGetCreateSchemaSql2() { $classes = array( $this->_em->getClassMetadata('Doctrine\Tests\Models\Generic\DecimalModel') ); $tool = new SchemaTool($this->_em); $sql = $tool->getCreateSchemaSql($classes); $this->assertEquals(1, count($sql)); $this->assertEquals("CREATE TABLE decimal_model (id INT AUTO_INCREMENT NOT NULL, `decimal` NUMERIC(5, 2) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB", $sql[0]); } public function testGetCreateSchemaSql3() { $classes = array( $this->_em->getClassMetadata('Doctrine\Tests\Models\Generic\BooleanModel') ); $tool = new SchemaTool($this->_em); $sql = $tool->getCreateSchemaSql($classes); $this->assertEquals(1, count($sql)); $this->assertEquals("CREATE TABLE boolean_model (id INT AUTO_INCREMENT NOT NULL, booleanField TINYINT(1) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB", $sql[0]); } public function testGetUpdateSchemaSql() { $this->markTestSkipped('Update Schema Tool stuff wont be needed anymore soon!'); $classes = array( $this->_em->getClassMetadata(__NAMESPACE__ . '\SchemaToolEntityA') ); $tool = new SchemaTool($this->_em); $tool->createSchema($classes); // Add field to SchemaToolEntityA $classA = $classes[0]; $classA->mapField(array( 'fieldName' => 'newField', 'columnName' => 'new_field', 'type' => 'string', 'length' => 50, 'nullable' => false )); // Test create column with no length and nullable defaults to 255, NOT NULL $classA->mapField(array( 'fieldName' => 'newField2', 'columnName' => 'new_field2', 'type' => 'string', )); // Introduce SchemaToolEntityB $classB = new ClassMetadata(__NAMESPACE__ . '\SchemaToolEntityB'); $classB->setTableName('schematool_entity_b'); $classB->mapField(array( 'fieldName' => 'id', 'columnName' => 'id', 'type' => 'integer', 'nullable' => false, 'id' => true )); $classB->mapField(array( 'fieldName' => 'field', 'columnName' => 'field', 'type' => 'string', 'nullable' => false )); $classes[] = $classB; $sql = $tool->getUpdateSchemaSql($classes); $this->assertEquals(2, count($sql)); $this->assertEquals("CREATE TABLE schematool_entity_b (id INT NOT NULL, field VARCHAR(255) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB", $sql[0]); $this->assertEquals("ALTER TABLE schematool_entity_a ADD new_field VARCHAR(50) NOT NULL, ADD new_field2 VARCHAR(255) NOT NULL", $sql[1]); $tool->updateSchema($classes); // Change from 50 to default value (by setting null) $classA->fieldMappings['newField']['length'] = null; $sql = $tool->getUpdateSchemaSql($classes); $this->assertEquals(1, count($sql)); $this->assertEquals("ALTER TABLE schematool_entity_a CHANGE new_field new_field VARCHAR(255) NOT NULL", $sql[0]); } } /** @Entity @Table(name="schematool_entity_a") */ class SchemaToolEntityA { /** @Id @Column(type="integer") */ private $id; private $newField; private $newField2; } class SchemaToolEntityB { private $id; private $field; }