2009-12-04 21:40:03 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Functional;
|
|
|
|
|
|
|
|
require_once __DIR__ . '/../../TestInit.php';
|
|
|
|
|
2010-03-24 15:31:54 +00:00
|
|
|
use Doctrine\ORM\Tools\ClassMetadataReader;
|
2009-12-04 21:40:03 +00:00
|
|
|
|
|
|
|
class DatabaseDriverTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|
|
|
{
|
2009-12-04 21:58:16 +00:00
|
|
|
/**
|
|
|
|
* @var \Doctrine\DBAL\Schema\AbstractSchemaManager
|
|
|
|
*/
|
2009-12-04 21:40:03 +00:00
|
|
|
protected $_sm = null;
|
|
|
|
|
2009-12-04 21:58:16 +00:00
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->_sm = $this->_em->getConnection()->getSchemaManager();
|
|
|
|
}
|
|
|
|
|
2009-12-04 21:40:03 +00:00
|
|
|
public function testCreateSimpleYamlFromDatabase()
|
|
|
|
{
|
2010-02-07 12:36:30 +00:00
|
|
|
if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) {
|
|
|
|
$this->markTestSkipped('Platform does not support foreign keys.');
|
|
|
|
}
|
|
|
|
|
2009-12-04 21:40:03 +00:00
|
|
|
$table = new \Doctrine\DBAL\Schema\Table("dbdriver_foo");
|
2010-02-25 21:51:30 +00:00
|
|
|
$table->addColumn('id', 'integer');
|
2009-12-04 21:40:03 +00:00
|
|
|
$table->setPrimaryKey(array('id'));
|
2010-02-25 21:51:30 +00:00
|
|
|
$table->addColumn('bar', 'string', array('length' => 200));
|
2009-12-04 21:40:03 +00:00
|
|
|
|
|
|
|
$this->_sm->dropAndCreateTable($table);
|
|
|
|
|
2009-12-05 09:39:11 +00:00
|
|
|
$metadata = $this->extractClassMetadata("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->assertTrue($metadata->fieldMappings['id']['notnull']);
|
|
|
|
|
|
|
|
$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']['notnull']);
|
2009-12-04 21:40:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testCreateYamlWithForeignKeyFromDatabase()
|
|
|
|
{
|
|
|
|
if (!$this->_em->getConnection()->getDatabasePlatform()->supportsForeignKeyConstraints()) {
|
|
|
|
$this->markTestSkipped('Platform does not support foreign keys.');
|
|
|
|
}
|
|
|
|
|
|
|
|
$tableB = new \Doctrine\DBAL\Schema\Table("dbdriver_bar");
|
2010-02-25 21:51:30 +00:00
|
|
|
$tableB->addColumn('id', 'integer');
|
2009-12-04 21:40:03 +00:00
|
|
|
$tableB->setPrimaryKey(array('id'));
|
|
|
|
|
2009-12-05 09:39:11 +00:00
|
|
|
$this->_sm->dropAndCreateTable($tableB);
|
2009-12-04 21:40:03 +00:00
|
|
|
|
|
|
|
$tableA = new \Doctrine\DBAL\Schema\Table("dbdriver_baz");
|
2010-02-25 21:51:30 +00:00
|
|
|
$tableA->addColumn('id', 'integer');
|
2009-12-04 21:40:03 +00:00
|
|
|
$tableA->setPrimaryKey(array('id'));
|
2010-02-25 21:51:30 +00:00
|
|
|
$tableA->addColumn('bar_id', 'integer');
|
2009-12-04 21:40:03 +00:00
|
|
|
$tableA->addForeignKeyConstraint('dbdriver_bar', array('bar_id'), array('id'));
|
|
|
|
|
|
|
|
$this->_sm->dropAndCreateTable($tableA);
|
|
|
|
|
2009-12-05 09:39:11 +00:00
|
|
|
$metadata = $this->extractClassMetadata("DbdriverBaz");
|
|
|
|
|
|
|
|
$this->assertArrayNotHasKey('bar', $metadata->fieldMappings);
|
|
|
|
$this->assertArrayHasKey('id', $metadata->fieldMappings);
|
|
|
|
|
|
|
|
$metadata->associationMappings = \array_change_key_case($metadata->associationMappings, \CASE_LOWER);
|
|
|
|
|
|
|
|
$this->assertArrayHasKey('bar', $metadata->associationMappings);
|
|
|
|
$this->assertType('Doctrine\ORM\Mapping\OneToOneMapping', $metadata->associationMappings['bar']);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $className
|
|
|
|
* @return ClassMetadata
|
|
|
|
*/
|
|
|
|
protected function extractClassMetadata($className)
|
|
|
|
{
|
2010-03-24 15:31:54 +00:00
|
|
|
$cm = new ClassMetadataReader();
|
|
|
|
$cm->addMappingSource(new \Doctrine\ORM\Mapping\Driver\DatabaseDriver($this->_sm));
|
2010-03-19 04:19:15 +00:00
|
|
|
$metadatas = $cm->getMetadatas();
|
2009-12-05 09:39:11 +00:00
|
|
|
|
|
|
|
$output = false;
|
2010-01-28 12:46:12 +00:00
|
|
|
|
2009-12-05 09:39:11 +00:00
|
|
|
foreach ($metadatas AS $metadata) {
|
2010-02-07 12:36:30 +00:00
|
|
|
if (strtolower($metadata->name) == strtolower($className)) {
|
2009-12-05 09:39:11 +00:00
|
|
|
return $metadata;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->fail("No class matching the name '".$className."' was found!");
|
2009-12-04 21:40:03 +00:00
|
|
|
}
|
|
|
|
}
|