useModelSet('cms'); parent::setUp(); $this->_sm = $this->_em->getConnection()->getSchemaManager(); } /** * @group DDC-2059 */ public function testIssue2059() { if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) { $this->markTestSkipped('Platform does not support foreign keys.'); } $user = new Table("ddc2059_user"); $user->addColumn('id', 'integer'); $user->setPrimaryKey(['id']); $project = new Table("ddc2059_project"); $project->addColumn('id', 'integer'); $project->addColumn('user_id', 'integer'); $project->addColumn('user', 'string'); $project->setPrimaryKey(['id']); $project->addForeignKeyConstraint('ddc2059_user', ['user_id'], ['id']); $metadata = $this->convertToClassMetadata([$project, $user], []); $this->assertTrue(isset($metadata['Ddc2059Project']->fieldMappings['user'])); $this->assertTrue(isset($metadata['Ddc2059Project']->associationMappings['user2'])); } public function testLoadMetadataFromDatabase() { if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) { $this->markTestSkipped('Platform does not support foreign keys.'); } $table = new Table("dbdriver_foo"); $table->addColumn('id', 'integer'); $table->setPrimaryKey(['id']); $table->addColumn('bar', 'string', ['notnull' => false, 'length' => 200]); $this->_sm->dropAndCreateTable($table); $metadatas = $this->extractClassMetadata(["DbdriverFoo"]); $this->assertArrayHasKey('DbdriverFoo', $metadatas); $metadata = $metadatas['DbdriverFoo']; $this->assertArrayHasKey('id', $metadata->fieldMappings); $this->assertEquals('id', $metadata->fieldMappings['id']['fieldName']); $this->assertEquals('id', strtolower($metadata->fieldMappings['id']['columnName'])); $this->assertEquals('integer', (string)$metadata->fieldMappings['id']['type']); $this->assertArrayHasKey('bar', $metadata->fieldMappings); $this->assertEquals('bar', $metadata->fieldMappings['bar']['fieldName']); $this->assertEquals('bar', strtolower($metadata->fieldMappings['bar']['columnName'])); $this->assertEquals('string', (string)$metadata->fieldMappings['bar']['type']); $this->assertEquals(200, $metadata->fieldMappings['bar']['length']); $this->assertTrue($metadata->fieldMappings['bar']['nullable']); } public function testLoadMetadataWithForeignKeyFromDatabase() { if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) { $this->markTestSkipped('Platform does not support foreign keys.'); } $tableB = new Table("dbdriver_bar"); $tableB->addColumn('id', 'integer'); $tableB->setPrimaryKey(['id']); $this->_sm->dropAndCreateTable($tableB); $tableA = new Table("dbdriver_baz"); $tableA->addColumn('id', 'integer'); $tableA->setPrimaryKey(['id']); $tableA->addColumn('bar_id', 'integer'); $tableA->addForeignKeyConstraint('dbdriver_bar', ['bar_id'], ['id']); $this->_sm->dropAndCreateTable($tableA); $metadatas = $this->extractClassMetadata(["DbdriverBar", "DbdriverBaz"]); $this->assertArrayHasKey('DbdriverBaz', $metadatas); $bazMetadata = $metadatas['DbdriverBaz']; $this->assertArrayNotHasKey('barId', $bazMetadata->fieldMappings, "The foreign Key field should not be inflected as 'barId' field, its an association."); $this->assertArrayHasKey('id', $bazMetadata->fieldMappings); $bazMetadata->associationMappings = \array_change_key_case($bazMetadata->associationMappings, \CASE_LOWER); $this->assertArrayHasKey('bar', $bazMetadata->associationMappings); $this->assertEquals(ClassMetadataInfo::MANY_TO_ONE, $bazMetadata->associationMappings['bar']['type']); } public function testDetectManyToManyTables() { if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) { $this->markTestSkipped('Platform does not support foreign keys.'); } $metadatas = $this->extractClassMetadata(["CmsUsers", "CmsGroups", "CmsTags"]); $this->assertArrayHasKey('CmsUsers', $metadatas, 'CmsUsers entity was not detected.'); $this->assertArrayHasKey('CmsGroups', $metadatas, 'CmsGroups entity was not detected.'); $this->assertArrayHasKey('CmsTags', $metadatas, 'CmsTags entity was not detected.'); $this->assertEquals(3, count($metadatas['CmsUsers']->associationMappings)); $this->assertArrayHasKey('group', $metadatas['CmsUsers']->associationMappings); $this->assertEquals(1, count($metadatas['CmsGroups']->associationMappings)); $this->assertArrayHasKey('user', $metadatas['CmsGroups']->associationMappings); $this->assertEquals(1, count($metadatas['CmsTags']->associationMappings)); $this->assertArrayHasKey('user', $metadatas['CmsGroups']->associationMappings); } public function testIgnoreManyToManyTableWithoutFurtherForeignKeyDetails() { $tableB = new Table("dbdriver_bar"); $tableB->addColumn('id', 'integer'); $tableB->setPrimaryKey(['id']); $tableA = new Table("dbdriver_baz"); $tableA->addColumn('id', 'integer'); $tableA->setPrimaryKey(['id']); $tableMany = new Table("dbdriver_bar_baz"); $tableMany->addColumn('bar_id', 'integer'); $tableMany->addColumn('baz_id', 'integer'); $tableMany->addForeignKeyConstraint('dbdriver_bar', ['bar_id'], ['id']); $metadatas = $this->convertToClassMetadata([$tableA, $tableB], [$tableMany]); $this->assertEquals(0, count($metadatas['DbdriverBaz']->associationMappings), "no association mappings should be detected."); } public function testLoadMetadataFromDatabaseDetail() { if ( ! $this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) { $this->markTestSkipped('Platform does not support foreign keys.'); } $table = new Table("dbdriver_foo"); $table->addColumn('id', 'integer', ['unsigned' => true]); $table->setPrimaryKey(['id']); $table->addColumn('column_unsigned', 'integer', ['unsigned' => true]); $table->addColumn('column_comment', 'string', ['comment' => 'test_comment']); $table->addColumn('column_default', 'string', ['default' => 'test_default']); $table->addColumn('column_decimal', 'decimal', ['precision' => 4, 'scale' => 3]); $table->addColumn('column_index1', 'string'); $table->addColumn('column_index2', 'string'); $table->addIndex(['column_index1','column_index2'], 'index1'); $table->addColumn('column_unique_index1', 'string'); $table->addColumn('column_unique_index2', 'string'); $table->addUniqueIndex(['column_unique_index1', 'column_unique_index2'], 'unique_index1'); $this->_sm->dropAndCreateTable($table); $metadatas = $this->extractClassMetadata(["DbdriverFoo"]); $this->assertArrayHasKey('DbdriverFoo', $metadatas); $metadata = $metadatas['DbdriverFoo']; $this->assertArrayHasKey('id', $metadata->fieldMappings); $this->assertEquals('id', $metadata->fieldMappings['id']['fieldName']); $this->assertEquals('id', strtolower($metadata->fieldMappings['id']['columnName'])); $this->assertEquals('integer', (string) $metadata->fieldMappings['id']['type']); // FIXME: Condition here is fugly. // NOTE: PostgreSQL and SQL SERVER do not support UNSIGNED integer if ( ! $this->_em->getConnection()->getDatabasePlatform() instanceof PostgreSqlPlatform AND ! $this->_em->getConnection()->getDatabasePlatform() instanceof SQLServerPlatform) { $this->assertArrayHasKey('columnUnsigned', $metadata->fieldMappings); $this->assertTrue($metadata->fieldMappings['columnUnsigned']['options']['unsigned']); } $this->assertArrayHasKey('columnComment', $metadata->fieldMappings); $this->assertEquals('test_comment', $metadata->fieldMappings['columnComment']['options']['comment']); $this->assertArrayHasKey('columnDefault', $metadata->fieldMappings); $this->assertEquals('test_default', $metadata->fieldMappings['columnDefault']['options']['default']); $this->assertArrayHasKey('columnDecimal', $metadata->fieldMappings); $this->assertEquals(4, $metadata->fieldMappings['columnDecimal']['precision']); $this->assertEquals(3, $metadata->fieldMappings['columnDecimal']['scale']); $this->assertTrue( ! empty($metadata->table['indexes']['index1']['columns'])); $this->assertEquals( ['column_index1','column_index2'], $metadata->table['indexes']['index1']['columns'] ); $this->assertTrue( ! empty($metadata->table['uniqueConstraints']['unique_index1']['columns'])); $this->assertEquals( ['column_unique_index1', 'column_unique_index2'], $metadata->table['uniqueConstraints']['unique_index1']['columns'] ); } }