DDC-646 - Bugfix with missing inclusion of Namespace, added test for ConvertDoctrine1SchemaCommand
This commit is contained in:
parent
440a255e5a
commit
51e6681934
3 changed files with 101 additions and 10 deletions
|
@ -25,7 +25,8 @@ use Symfony\Components\Console\Input\InputArgument,
|
|||
Symfony\Components\Console\Input\InputOption,
|
||||
Symfony\Components\Console,
|
||||
Doctrine\ORM\Tools\Export\ClassMetadataExporter,
|
||||
Doctrine\ORM\Tools\ConvertDoctrine1Schema;
|
||||
Doctrine\ORM\Tools\ConvertDoctrine1Schema,
|
||||
Doctrine\ORM\Tools\EntityGenerator;
|
||||
|
||||
/**
|
||||
* Command to convert a Doctrine 1 schema to a Doctrine 2 mapping file.
|
||||
|
@ -41,6 +42,56 @@ use Symfony\Components\Console\Input\InputArgument,
|
|||
*/
|
||||
class ConvertDoctrine1SchemaCommand extends Console\Command\Command
|
||||
{
|
||||
/**
|
||||
* @var EntityGenerator
|
||||
*/
|
||||
private $entityGenerator = null;
|
||||
|
||||
/**
|
||||
* @var ClassMetadataExporter
|
||||
*/
|
||||
private $metadataExporter = null;
|
||||
|
||||
/**
|
||||
* @return EntityGenerator
|
||||
*/
|
||||
public function getEntityGenerator()
|
||||
{
|
||||
if ($this->entityGenerator == null) {
|
||||
$this->entityGenerator = new EntityGenerator();
|
||||
}
|
||||
|
||||
return $this->entityGenerator;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param EntityGenerator $entityGenerator
|
||||
*/
|
||||
public function setEntityGenerator(EntityGenerator $entityGenerator)
|
||||
{
|
||||
$this->entityGenerator = $entityGenerator;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return ClassMetadataExporter
|
||||
*/
|
||||
public function getMetadataExporter()
|
||||
{
|
||||
if ($this->metadataExporter == null) {
|
||||
$this->metadataExporter = new ClassMetadataExporter();
|
||||
}
|
||||
|
||||
return $this->metadataExporter;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param ClassMetadataExporter $metadataExporter
|
||||
*/
|
||||
public function setMetadataExporter(ClassMetadataExporter $metadataExporter)
|
||||
{
|
||||
$this->metadataExporter = $metadataExporter;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see Console\Command\Command
|
||||
*/
|
||||
|
@ -90,6 +141,27 @@ EOT
|
|||
// Process source directories
|
||||
$fromPaths = array_merge(array($input->getArgument('from-path')), $input->getOption('from'));
|
||||
|
||||
// Process destination directory
|
||||
$destPath = realpath($input->getArgument('dest-path'));
|
||||
|
||||
$toType = $input->getArgument('to-type');
|
||||
$extend = $input->getOption('extend');
|
||||
$numSpaces = $input->getOption('num-spaces');
|
||||
|
||||
$this->convertDoctrine1Schema($em, $fromPaths, $destPath, $toType, $numSpaces, $extend, $output);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param \Doctrine\ORM\EntityManager $em
|
||||
* @param array $fromPaths
|
||||
* @param string $destPath
|
||||
* @param string $toType
|
||||
* @param int $numSpaces
|
||||
* @param string|null $extend
|
||||
* @param Console\Output\OutputInterface $output
|
||||
*/
|
||||
public function convertDoctrine1Schema($em, $fromPaths, $destPath, $toType, $numSpaces, $extend, $output)
|
||||
{
|
||||
foreach ($fromPaths as &$dirName) {
|
||||
$dirName = realpath($dirName);
|
||||
|
||||
|
@ -104,9 +176,6 @@ EOT
|
|||
}
|
||||
}
|
||||
|
||||
// Process destination directory
|
||||
$destPath = realpath($input->getArgument('dest-path'));
|
||||
|
||||
if ( ! file_exists($destPath)) {
|
||||
throw new \InvalidArgumentException(
|
||||
sprintf("Doctrine 2.X mapping destination directory '<info>%s</info>' does not exist.", $destPath)
|
||||
|
@ -117,18 +186,16 @@ EOT
|
|||
);
|
||||
}
|
||||
|
||||
$toType = $input->getArgument('to-type');
|
||||
|
||||
$cme = new ClassMetadataExporter();
|
||||
$cme = $this->getMetadataExporter();
|
||||
$exporter = $cme->getExporter($toType, $destPath);
|
||||
|
||||
if (strtolower($toType) === 'annotation') {
|
||||
$entityGenerator = new EntityGenerator();
|
||||
$entityGenerator = $this->getEntityGenerator();
|
||||
$exporter->setEntityGenerator($entityGenerator);
|
||||
|
||||
$entityGenerator->setNumSpaces($input->getOption('num-spaces'));
|
||||
$entityGenerator->setNumSpaces($numSpaces);
|
||||
|
||||
if (($extend = $input->getOption('extend')) !== null) {
|
||||
if ($extend !== null) {
|
||||
$entityGenerator->setClassToExtend($extend);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -28,6 +28,7 @@ class AllTests
|
|||
$suite->addTestSuite('Doctrine\Tests\ORM\Tools\SchemaToolTest');
|
||||
$suite->addTestSuite('Doctrine\Tests\ORM\Tools\EntityGeneratorTest');
|
||||
$suite->addTestSuite('Doctrine\Tests\ORM\Tools\SchemaValidatorTest');
|
||||
$suite->addTestSuite('Doctrine\Tests\ORM\Tools\Console\Command\ConvertDoctrine1SchemaCommandTest');
|
||||
|
||||
return $suite;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,23 @@
|
|||
<?php
|
||||
|
||||
namespace Doctrine\Tests\ORM\Tools\Console\Command;
|
||||
|
||||
use Doctrine\ORM\Tools\Console\Command\ConvertDoctrine1SchemaCommand;
|
||||
|
||||
class ConvertDoctrine1SchemaCommandTest extends \Doctrine\Tests\OrmTestCase
|
||||
{
|
||||
public function testExecution()
|
||||
{
|
||||
$entityGenerator = $this->getMock('Doctrine\ORM\Tools\EntityGenerator');
|
||||
$metadataExporter = $this->getMock('Doctrine\ORM\Tools\Export\ClassMetadataExporter');
|
||||
$command = new ConvertDoctrine1SchemaCommand();
|
||||
$command->setEntityGenerator($entityGenerator);
|
||||
|
||||
$output = $this->getMock('Symfony\Components\Console\Output\OutputInterface');
|
||||
$output->expects($this->once())
|
||||
->method('write')
|
||||
->with($this->equalTo('No Metadata Classes to process.' . PHP_EOL));
|
||||
|
||||
$command->convertDoctrine1Schema($this->_getTestEntityManager(), array(), sys_get_temp_dir(), 'annotation', 4, null, $output);
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue