diff --git a/lib/Doctrine/ORM/DefaultNamingStrategy.php b/lib/Doctrine/ORM/DefaultNamingStrategy.php index 7e712a3bb..f12db9a9f 100644 --- a/lib/Doctrine/ORM/DefaultNamingStrategy.php +++ b/lib/Doctrine/ORM/DefaultNamingStrategy.php @@ -30,12 +30,15 @@ namespace Doctrine\ORM; */ class DefaultNamingStrategy implements NamingStrategy { - /** * {@inheritdoc} */ public function classToTableName($className) { + if (strpos($className, '\\') !== false) { + return substr($className, strrpos($className, '\\') + 1); + } + return $className; } @@ -50,64 +53,34 @@ class DefaultNamingStrategy implements NamingStrategy /** * {@inheritdoc} */ - public function tableName($tableName) + public function referenceColumnName() { - return $tableName; + return 'id'; } /** * {@inheritdoc} */ - public function columnName($columnName) + public function joinColumnName($propertyName) { - return $columnName; + return $propertyName . '_' . $this->referenceColumnName(); } /** * {@inheritdoc} */ - public function collectionTableName($ownerEntity, $ownerEntityTable, $associatedEntity, $associatedEntityTable, $propertyName) + public function joinTableName($ownerEntity, $associatedEntity, $propertyName = null) { - return $propertyName; + return strtolower($this->classToTableName($ownerEntity) . '_' . + $this->classToTableName($associatedEntity)); } - + /** * {@inheritdoc} */ - public function joinKeyColumnName($joinedColumn, $joinedTable) + public function joinKeyColumnName($propertyEntityName, $referencedColumnName = null, $propertyName = null) { - return $joinedColumn; + return strtolower($this->classToTableName($propertyEntityName) . '_' . + ($referencedColumnName ?: $this->referenceColumnName())); } - - /** - * {@inheritdoc} - */ - public function foreignKeyColumnName($propertyName, $propertyEntityName, $propertyTableName, $referencedColumnName) - { - return $propertyName ?: $propertyTableName; - } - - /** - * {@inheritdoc} - */ - public function logicalColumnName($columnName, $propertyName) - { - return $columnName ?: $propertyName; - } - - /** - * {@inheritdoc} - */ - public function logicalCollectionTableName($tableName, $ownerEntityTable, $associatedEntityTable, $propertyName) - { - return $ownerEntityTable . '_' . ( $associatedEntityTable ?: $propertyName ); - } - - /** - * {@inheritdoc} - */ - public function logicalCollectionColumnName($columnName, $propertyName, $referencedColumn) - { - return $columnName ?: ($propertyName . '_' . $referencedColumn); - } -} +} \ No newline at end of file diff --git a/lib/Doctrine/ORM/NamingStrategy.php b/lib/Doctrine/ORM/NamingStrategy.php index ff72be46f..e91e334ad 100644 --- a/lib/Doctrine/ORM/NamingStrategy.php +++ b/lib/Doctrine/ORM/NamingStrategy.php @@ -40,82 +40,43 @@ interface NamingStrategy function classToTableName($className); /** - * Return a column name for a property path expression + * Return a column name for a property * - * @param string $propertyName A property path + * @param string $propertyName A property * @return string A column name */ function propertyToColumnName($propertyName); /** - * Alter the table name given in the mapping document + * Return the default reference column name * - * @param string tableName A table name - * @return string A table name - */ - function tableName($tableName); - - /** - * Alter the column name given in the mapping document - * - * @param string $columnName A column name * @return string A column name */ - function columnName($columnName); + function referenceColumnName(); + + /** + * Return a join column name for a property + * + * @param string $propertyName A property + * @return string A column name + */ + function joinColumnName($propertyName); /** - * Return a collection table name ie an association having a join table + * Return a join table name * * @param string $ownerEntity - * @param string $ownerEntityTable Owner side table name * @param string $associatedEntity - * @param string $associatedEntityTable Reverse side table name if any - * @param string $propertyName Collection role + * @param string $propertyName */ - function collectionTableName($ownerEntity, $ownerEntityTable, $associatedEntity, $associatedEntityTable, $propertyName); + function joinTableName($ownerEntity, $associatedEntity, $propertyName = null); - /** - * Return the join key column name ie a FK column used in a JOINED strategy or for a secondary table - * - * @param string $joinedColumn Joined column name used to join with - * @param string $joinedTable Joined table name used to join with - */ - function joinKeyColumnName($joinedColumn, $joinedTable); - - /** + /** * Return the foreign key column name for the given parameters * - * @param string $propertyName The property name involved * @param string $propertyEntityName - * @param string $propertyTableName The property table name involved (logical one) - * @param string $referencedColumnName The referenced column name involved (logical one) + * @param string $referencedColumnName + * @param string $propertyName */ - function foreignKeyColumnName($propertyName, $propertyEntityName, $propertyTableName, $referencedColumnName); - - /** - * Return the logical column name used to refer to a column in the metadata - * - * @param string $columnName Given column name if any - * @param string $propertyName Property name of this column - */ - function logicalColumnName($columnName, $propertyName); - - /** - * Returns the logical collection table name used to refer to a table in the mapping metadata - * - * @param string $tableName The metadata explicit name - * @param string $ownerEntityTable Owner table entity table name (logical one) - * @param string $associatedEntityTable Reverse side table name if any (logical one) - * @param string $propertyName Collection role - */ - function logicalCollectionTableName($tableName, $ownerEntityTable, $associatedEntityTable, $propertyName); - - /** - * Returns the logical foreign key column name used to refer to this column in the mapping metadata - * - * @param string $columnName Given column name in the metadata if any - * @param string $propertyName Property name - * @param string $referencedColumn Referenced column name in the join - */ - function logicalCollectionColumnName($columnName, $propertyName, $referencedColumn); -} + function joinKeyColumnName($propertyEntityName, $referencedColumnName = null, $propertyName = null); +} \ No newline at end of file diff --git a/tests/Doctrine/Tests/ORM/NamingStrategyTest.php b/tests/Doctrine/Tests/ORM/NamingStrategyTest.php index 08b8c1b51..f17459118 100644 --- a/tests/Doctrine/Tests/ORM/NamingStrategyTest.php +++ b/tests/Doctrine/Tests/ORM/NamingStrategyTest.php @@ -39,11 +39,11 @@ class NamingStrategyTest extends \Doctrine\Tests\OrmTestCase array(self::defaultNaming(), 'SomeClassName', 'SomeClassName' ), - array(self::defaultNaming(), 'SOME_CLASS_NAME', - 'SOME_CLASS_NAME' + array(self::defaultNaming(), 'SomeClassName', + '\SomeClassName' ), - array(self::defaultNaming(), 'some_class_name', - 'some_class_name' + array(self::defaultNaming(), 'Name', + '\Some\Class\Name' ), ); } @@ -51,7 +51,7 @@ class NamingStrategyTest extends \Doctrine\Tests\OrmTestCase /** * @dataProvider dataClassToTableName */ - public function testClassToTableName(NamingStrategy $strategy, $className, $expected) + public function testClassToTableName(NamingStrategy $strategy, $expected, $className) { $this->assertEquals($expected, $strategy->classToTableName($className)); } @@ -89,103 +89,94 @@ class NamingStrategyTest extends \Doctrine\Tests\OrmTestCase } /** - * Data Provider for NamingStrategy#tableName + * Data Provider for NamingStrategy#referenceColumnName * * @return array */ - static public function dataTableName() + static public function dataReferenceColumnName() { return array( - array(self::defaultNaming(), 'someTable', - 'someTable' - ), - array(self::defaultNaming(), 'SOME_TABLE', - 'SOME_TABLE' - ), - array(self::defaultNaming(), 'some_table', - 'some_table' - ), + array(self::defaultNaming(), 'id'), ); } - + /** - * @dataProvider dataTableName - * + * @dataProvider dataReferenceColumnName + * * @param NamingStrategy $strategy * @param string $expected - * @param string $tableName + * @param string $joinedColumn + * @param string $joinedTable */ - public function testTableName(NamingStrategy $strategy, $expected, $tableName) + public function testReferenceColumnName(NamingStrategy $strategy, $expected) { - $this->assertEquals($expected, $strategy->tableName($tableName)); + $this->assertEquals($expected, $strategy->referenceColumnName()); } /** - * Data Provider for NamingStrategy#columnName + * Data Provider for NamingStrategy#joinColumnName * * @return array */ - static public function dataColumnName() + static public function dataJoinColumnName() { return array( - array(self::defaultNaming(), 'someColumn', - 'someColumn' + array(self::defaultNaming(), 'someColumn_id', + 'someColumn', null, ), - array(self::defaultNaming(), 'SOME_COLUMN', - 'SOME_COLUMN' + array(self::defaultNaming(), 'somecolumn_id', + 'somecolumn', null, ), - array(self::defaultNaming(), 'some_column', - 'some_column' + array(self::defaultNaming(), 'some_column_id', + 'some_column', null, ), ); } - + /** - * @dataProvider dataColumnName - * + * @dataProvider dataJoinColumnName + * * @param NamingStrategy $strategy * @param string $expected - * @param string $columnName + * @param string $propertyName */ - public function testColumnName(NamingStrategy $strategy, $expected, $columnName) + public function testJoinColumnName(NamingStrategy $strategy, $expected, $propertyName) { - $this->assertEquals($expected, $strategy->columnName($columnName)); + $this->assertEquals($expected, $strategy->joinColumnName($propertyName)); } /** - * Data Provider for NamingStrategy#collectionTableName + * Data Provider for NamingStrategy#joinTableName * * @return array */ - static public function dataCollectionTableName() + static public function dataJoinTableName() { return array( - array(self::defaultNaming(), 'someColumn', - null, null, null, null, 'someColumn', + array(self::defaultNaming(), 'someclassname_classname', + 'SomeClassName', 'Some\ClassName', null, ), - array(self::defaultNaming(), 'SOME_COLUMN', - null, null, null, null, 'SOME_COLUMN' + array(self::defaultNaming(), 'someclassname_classname', + '\SomeClassName', 'ClassName', null, ), - array(self::defaultNaming(), 'some_column', - null, null, null, null, 'some_column' + array(self::defaultNaming(), 'name_classname', + '\Some\Class\Name', 'ClassName', null, ), ); } /** - * @dataProvider dataCollectionTableName + * @dataProvider dataJoinTableName * * @param NamingStrategy $strategy * @param string $expected * @param string $ownerEntity - * @param string $ownerEntityTable * @param string $associatedEntity - * @param string $associatedEntityTable * @param string $propertyName */ - public function testCollectionTableName(NamingStrategy $strategy, $expected, $ownerEntity, $ownerEntityTable, $associatedEntity, $associatedEntityTable, $propertyName) + public function testJoinTableName(NamingStrategy $strategy, $expected, $ownerEntity, $associatedEntity, $propertyName = null) { - $this->assertEquals($expected, $strategy->collectionTableName($ownerEntity, $ownerEntityTable, $associatedEntity, $associatedEntityTable, $propertyName)); + $this->assertEquals($expected, $strategy->joinTableName($ownerEntity, $associatedEntity, $propertyName)); } /** @@ -196,14 +187,11 @@ class NamingStrategyTest extends \Doctrine\Tests\OrmTestCase static public function dataJoinKeyColumnName() { return array( - array(self::defaultNaming(), 'someColumn', - 'someColumn', null, + array(self::defaultNaming(), 'someclassname_id', + 'SomeClassName', null, null, ), - array(self::defaultNaming(), 'SOME_COLUMN', - 'SOME_COLUMN', null, - ), - array(self::defaultNaming(), 'some_column', - 'some_column', null, + array(self::defaultNaming(), 'name_identifier', + '\Some\Class\Name', 'identifier', null, ), ); } @@ -213,188 +201,12 @@ class NamingStrategyTest extends \Doctrine\Tests\OrmTestCase * * @param NamingStrategy $strategy * @param string $expected - * @param string $joinedColumn - * @param string $joinedTable - */ - public function testJoinKeyColumnName(NamingStrategy $strategy, $expected, $joinedColumn, $joinedTable) - { - $this->assertEquals($expected, $strategy->joinKeyColumnName($joinedColumn, $joinedTable)); - } - - /** - * Data Provider for NamingStrategy#foreignKeyColumnName - * - * @return array - */ - static public function dataForeignKeyColumnName() - { - return array( - array(self::defaultNaming(), 'someColumn', - 'someColumn', null, null, null, - ), - array(self::defaultNaming(), 'SOME_COLUMN', - 'SOME_COLUMN', null, null, null, - ), - array(self::defaultNaming(), 'some_column', - 'some_column', null, null, null, - ), - - array(self::defaultNaming(), 'someColumn', - null, null, 'someColumn', null, - ), - array(self::defaultNaming(), 'SOME_COLUMN', - null, null, 'SOME_COLUMN', null, - ), - array(self::defaultNaming(), 'some_column', - null, null, 'some_column', null, - ), - ); - } - - /** - * @dataProvider dataForeignKeyColumnName - * - * @param NamingStrategy $strategy - * @param string $propertyName * @param string $propertyEntityName - * @param string $propertyTableName * @param string $referencedColumnName - */ - public function testForeignKeyColumnName(NamingStrategy $strategy, $expected, $propertyName, $propertyEntityName, $propertyTableName, $referencedColumnName) - { - $this->assertEquals($expected, $strategy->foreignKeyColumnName($propertyName, $propertyEntityName, $propertyTableName, $referencedColumnName)); - } - - /** - * Data Provider for NamingStrategy#logicalColumnName - * - * @return array - */ - static public function dataLogicalColumnName() - { - return array( - array(self::defaultNaming(), 'someColumn', - 'someColumn', null, - ), - array(self::defaultNaming(), 'SOME_COLUMN', - 'SOME_COLUMN', null, - ), - array(self::defaultNaming(), 'some_column', - 'some_column', null, - ), - - array(self::defaultNaming(), 'someColumn', - null, 'someColumn', - ), - array(self::defaultNaming(), 'SOME_COLUMN', - null, 'SOME_COLUMN', - ), - array(self::defaultNaming(), 'some_column', - null, 'some_column', - ), - ); - } - - /** - * @dataProvider dataLogicalColumnName - * - * @param NamingStrategy $strategy - * @param string $columnName * @param string $propertyName */ - public function testLogicalColumnName(NamingStrategy $strategy, $expected, $columnName, $propertyName) + public function testJoinKeyColumnName(NamingStrategy $strategy, $expected, $propertyEntityName, $referencedColumnName = null, $propertyName = null) { - $this->assertEquals($expected, $strategy->logicalColumnName($columnName, $propertyName)); + $this->assertEquals($expected, $strategy->joinKeyColumnName($propertyEntityName, $referencedColumnName, $propertyName)); } - - - /** - * Data Provider for NamingStrategy#logicalCollectionTableName - * - * @return array - */ - static public function dataLogicalCollectionTableName() - { - return array( - array(self::defaultNaming(), 'SomeClassName_SomeAssocClassName', - null, 'SomeClassName', 'SomeAssocClassName', null - ), - array(self::defaultNaming(), 'SOME_CLASS_NAME_SOME_ASSOC_CLASS_NAME', - null, 'SOME_CLASS_NAME', 'SOME_ASSOC_CLASS_NAME', null - ), - array(self::defaultNaming(), 'some_class_name_some_assoc_class_name', - null, 'some_class_name', 'some_assoc_class_name', null - ), - - array(self::defaultNaming(), 'SomeClassName_someProperty', - null, 'SomeClassName', null, 'someProperty', - ), - array(self::defaultNaming(), 'SOME_CLASS_NAME_SOME_PROPERTY', - null, 'SOME_CLASS_NAME', null, 'SOME_PROPERTY', - ), - array(self::defaultNaming(), 'some_class_name_some_property', - null, 'some_class_name', null, 'some_property', - ), - - ); - } - - /** - * @dataProvider dataLogicalCollectionTableName - * - * @param NamingStrategy $strategy - * @param string $tableName - * @param string $ownerEntityTable - * @param string $associatedEntityTable - * @param string $propertyName - */ - public function testLogicalCollectionTableName(NamingStrategy $strategy, $expected, $tableName, $ownerEntityTable, $associatedEntityTable, $propertyName) - { - $this->assertEquals($expected, $strategy->logicalCollectionTableName($tableName, $ownerEntityTable, $associatedEntityTable, $propertyName)); - } - - /** - * Data Provider for NamingStrategy#logicalCollectionColumnName - * - * @return array - */ - static public function dataLogicalCollectionColumnName() - { - return array( - array(self::defaultNaming(), 'someColumn', - 'someColumn', null, null, - ), - array(self::defaultNaming(), 'SOME_COLUMN', - 'SOME_COLUMN', null, null, - ), - array(self::defaultNaming(), 'some_column', - 'some_column', null, null, - ), - - array(self::defaultNaming(), 'someColumn', - 'someColumn', 'some', 'Column', - ), - array(self::defaultNaming(), 'SOME_COLUMN', - 'SOME_COLUMN', 'SOME', 'COLUMN', - ), - array(self::defaultNaming(), 'some_column', - 'some_column', 'some', 'column', - ), - - ); - } - - /** - * @dataProvider dataLogicalCollectionColumnName - * - * @param NamingStrategy $strategy - * @param string $columnName - * @param string $propertyName - * @param string $referencedColumn - */ - public function testLogicalCollectionColumnName(NamingStrategy $strategy, $expected, $columnName, $propertyName, $referencedColumn) - { - $this->assertEquals($expected, $strategy->logicalCollectionColumnName($columnName, $propertyName, $referencedColumn)); - } - } \ No newline at end of file