| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 | 
							- <?php
 - 
 - namespace Doctrine\Tests\ORM\Functional;
 - 
 - require_once __DIR__ . '/../../TestInit.php';
 - 
 - use Doctrine\ORM\Mapping\ClassMetadataInfo,
 -     Doctrine\Common\Util\Inflector;
 - 
 - class DatabaseDriverTest extends \Doctrine\Tests\OrmFunctionalTestCase
 - {
 -     /**
 -      * @var \Doctrine\DBAL\Schema\AbstractSchemaManager
 -      */
 -     protected $_sm = null;
 - 
 -     public function setUp()
 -     {
 -         $this->useModelSet('cms');
 -         parent::setUp();
 - 
 -         $this->_sm = $this->_em->getConnection()->getSchemaManager();
 -     }
 - 
 -     public function testLoadMetadataFromDatabase()
 -     {
 -         if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) {
 -             $this->markTestSkipped('Platform does not support foreign keys.');
 -         }
 - 
 -         $table = new \Doctrine\DBAL\Schema\Table("dbdriver_foo");
 -         $table->addColumn('id', 'integer');
 -         $table->setPrimaryKey(array('id'));
 -         $table->addColumn('bar', 'string', array('notnull' => false, 'length' => 200));
 - 
 -         $this->_sm->dropAndCreateTable($table);
 - 
 -         $metadatas = $this->extractClassMetadata(array("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 \Doctrine\DBAL\Schema\Table("dbdriver_bar");
 -         $tableB->addColumn('id', 'integer');
 -         $tableB->setPrimaryKey(array('id'));
 - 
 -         $this->_sm->dropAndCreateTable($tableB);
 - 
 -         $tableA = new \Doctrine\DBAL\Schema\Table("dbdriver_baz");
 -         $tableA->addColumn('id', 'integer');
 -         $tableA->setPrimaryKey(array('id'));
 -         $tableA->addColumn('bar_id', 'integer');
 -         $tableA->addForeignKeyConstraint('dbdriver_bar', array('bar_id'), array('id'));
 - 
 -         $this->_sm->dropAndCreateTable($tableA);
 - 
 -         $metadatas = $this->extractClassMetadata(array("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(array("CmsUsers", "CmsGroups"));
 - 
 -         $this->assertArrayHasKey('CmsUsers', $metadatas, 'CmsUsers entity was not detected.');
 -         $this->assertArrayHasKey('CmsGroups', $metadatas, 'CmsGroups entity was not detected.');
 - 
 -         $this->assertEquals(1, count($metadatas['CmsUsers']->associationMappings));
 -         $this->assertArrayHasKey('group', $metadatas['CmsUsers']->associationMappings);
 -         $this->assertEquals(1, count($metadatas['CmsGroups']->associationMappings));
 -         $this->assertArrayHasKey('user', $metadatas['CmsGroups']->associationMappings);
 -     }
 - 
 -     public function testIgnoreManyToManyTableWithoutFurtherForeignKeyDetails()
 -     {
 -         $tableB = new \Doctrine\DBAL\Schema\Table("dbdriver_bar");
 -         $tableB->addColumn('id', 'integer');
 -         $tableB->setPrimaryKey(array('id'));
 - 
 -         $tableA = new \Doctrine\DBAL\Schema\Table("dbdriver_baz");
 -         $tableA->addColumn('id', 'integer');
 -         $tableA->setPrimaryKey(array('id'));
 - 
 -         $tableMany = new \Doctrine\DBAL\Schema\Table("dbdriver_bar_baz");
 -         $tableMany->addColumn('bar_id', 'integer');
 -         $tableMany->addColumn('baz_id', 'integer');
 -         $tableMany->addForeignKeyConstraint('dbdriver_bar', array('bar_id'), array('id'));
 - 
 -         $metadatas = $this->convertToClassMetadata(array($tableA, $tableB), array($tableMany));
 - 
 -         $this->assertEquals(0, count($metadatas['DbdriverBaz']->associationMappings), "no association mappings should be detected.");
 -     }
 - 
 -     protected function convertToClassMetadata(array $entityTables, array $manyTables = array())
 -     {
 -         $driver = new \Doctrine\ORM\Mapping\Driver\DatabaseDriver($this->_sm);
 -         $driver->setTables($entityTables, $manyTables);
 - 
 -         $metadatas = array();
 -         foreach ($driver->getAllClassNames() AS $className) {
 -             $class = new ClassMetadataInfo($className);
 -             $driver->loadMetadataForClass($className, $class);
 -             $metadatas[$className] = $class;
 -         }
 - 
 -         return $metadatas;
 -     }
 - 
 -     /**
 -      * @param  string $className
 -      * @return ClassMetadata
 -      */
 -     protected function extractClassMetadata(array $classNames)
 -     {
 -         $classNames = array_map('strtolower', $classNames);
 -         $metadatas = array();
 - 
 -         $driver = new \Doctrine\ORM\Mapping\Driver\DatabaseDriver($this->_sm);
 -         foreach ($driver->getAllClassNames() as $className) {
 -             if (!in_array(strtolower($className), $classNames)) {
 -                 continue;
 -             }
 -             $class = new ClassMetadataInfo($className);
 -             $driver->loadMetadataForClass($className, $class);
 -             $metadatas[$className] = $class;
 -         }
 - 
 -         if (count($metadatas) != count($classNames)) {
 -             $this->fail("Have not found all classes matching the names '" . implode(", ", $classNames) . "' only tables " . implode(", ", array_keys($metadatas)));
 -         }
 -         return $metadatas;
 -     }
 - }
 
 
  |