PageRenderTime 47ms CodeModel.GetById 21ms RepoModel.GetById 0ms app.codeStats 0ms

/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Tools/Export/AbstractClassMetadataExporterTest.php

https://bitbucket.org/renta/jobeet2.loc
PHP | 391 lines | 325 code | 17 blank | 49 comment | 9 complexity | e79c0f013b39b99847dea1ffbd766f6c MD5 | raw file
Possible License(s): BSD-3-Clause, LGPL-3.0, LGPL-2.1, BSD-2-Clause, Apache-2.0, CC-BY-3.0
  1. <?php
  2. /*
  3. * $Id$
  4. *
  5. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  6. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  7. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  8. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  9. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  10. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  11. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  12. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  13. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  14. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  15. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  16. *
  17. * This software consists of voluntary contributions made by many individuals
  18. * and is licensed under the LGPL. For more information, see
  19. * <http://www.doctrine-project.org>.
  20. */
  21. namespace Doctrine\Tests\ORM\Tools\Export;
  22. use Doctrine\ORM\Tools\Export\ClassMetadataExporter;
  23. use Doctrine\ORM\Mapping\ClassMetadataInfo;
  24. use Doctrine\ORM\Tools\EntityGenerator;
  25. use Doctrine\Tests\Mocks\MetadataDriverMock;
  26. use Doctrine\Tests\Mocks\DatabasePlatformMock;
  27. use Doctrine\Tests\Mocks\EntityManagerMock;
  28. use Doctrine\Tests\Mocks\ConnectionMock;
  29. use Doctrine\Tests\Mocks\DriverMock;
  30. use Doctrine\Common\EventManager;
  31. use Doctrine\ORM\Tools\DisconnectedClassMetadataFactory;
  32. use Doctrine\ORM\Mapping\ClassMetadataFactory;
  33. require_once __DIR__ . '/../../../TestInit.php';
  34. /**
  35. * Test case for ClassMetadataExporter
  36. *
  37. * @author Jonathan H. Wage <jonwage@gmail.com>
  38. * @author Roman Borschel <roman@code-factory.org
  39. * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
  40. * @link http://www.phpdoctrine.org
  41. * @since 2.0
  42. * @version $Revision$
  43. */
  44. abstract class AbstractClassMetadataExporterTest extends \Doctrine\Tests\OrmTestCase
  45. {
  46. protected $_extension;
  47. abstract protected function _getType();
  48. protected function _createEntityManager($metadataDriver)
  49. {
  50. $driverMock = new DriverMock();
  51. $config = new \Doctrine\ORM\Configuration();
  52. $config->setProxyDir(__DIR__ . '/../../Proxies');
  53. $config->setProxyNamespace('Doctrine\Tests\Proxies');
  54. $eventManager = new EventManager();
  55. $conn = new ConnectionMock(array(), $driverMock, $config, $eventManager);
  56. $mockDriver = new MetadataDriverMock();
  57. $config->setMetadataDriverImpl($metadataDriver);
  58. return EntityManagerMock::create($conn, $config, $eventManager);
  59. }
  60. protected function _createMetadataDriver($type, $path)
  61. {
  62. $mappingDriver = array(
  63. 'php' => 'Doctrine\Common\Persistence\Mapping\Driver\PHPDriver',
  64. 'annotation' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
  65. 'xml' => 'Doctrine\ORM\Mapping\Driver\XmlDriver',
  66. 'yaml' => 'Doctrine\ORM\Mapping\Driver\YamlDriver',
  67. );
  68. $this->assertArrayHasKey($type, $mappingDriver, "There is no metadata driver for the type '" . $type . "'.");
  69. $class = $mappingDriver[$type];
  70. if ($type === 'annotation') {
  71. $driver = $this->createAnnotationDriver(array($path));
  72. } else {
  73. $driver = new $class($path);
  74. }
  75. return $driver;
  76. }
  77. protected function _createClassMetadataFactory($em, $type)
  78. {
  79. if ($type === 'annotation') {
  80. $factory = new ClassMetadataFactory();
  81. } else {
  82. $factory = new DisconnectedClassMetadataFactory();
  83. }
  84. $factory->setEntityManager($em);
  85. return $factory;
  86. }
  87. public function testExportDirectoryAndFilesAreCreated()
  88. {
  89. $this->_deleteDirectory(__DIR__ . '/export/'.$this->_getType());
  90. $type = $this->_getType();
  91. $metadataDriver = $this->_createMetadataDriver($type, __DIR__ . '/' . $type);
  92. $em = $this->_createEntityManager($metadataDriver);
  93. $cmf = $this->_createClassMetadataFactory($em, $type);
  94. $metadata = $cmf->getAllMetadata();
  95. $metadata[0]->name = 'Doctrine\Tests\ORM\Tools\Export\ExportedUser';
  96. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\ExportedUser', $metadata[0]->name);
  97. $type = $this->_getType();
  98. $cme = new ClassMetadataExporter();
  99. $exporter = $cme->getExporter($type, __DIR__ . '/export/' . $type);
  100. if ($type === 'annotation') {
  101. $entityGenerator = new EntityGenerator();
  102. $entityGenerator->setAnnotationPrefix("");
  103. $exporter->setEntityGenerator($entityGenerator);
  104. }
  105. $this->_extension = $exporter->getExtension();
  106. $exporter->setMetadata($metadata);
  107. $exporter->export();
  108. if ($type == 'annotation') {
  109. $this->assertTrue(file_exists(__DIR__ . '/export/' . $type . '/'.str_replace('\\', '/', 'Doctrine\Tests\ORM\Tools\Export\ExportedUser').$this->_extension));
  110. } else {
  111. $this->assertTrue(file_exists(__DIR__ . '/export/' . $type . '/Doctrine.Tests.ORM.Tools.Export.ExportedUser'.$this->_extension));
  112. }
  113. }
  114. /**
  115. * @depends testExportDirectoryAndFilesAreCreated
  116. */
  117. public function testExportedMetadataCanBeReadBackIn()
  118. {
  119. $type = $this->_getType();
  120. $metadataDriver = $this->_createMetadataDriver($type, __DIR__ . '/export/' . $type);
  121. $em = $this->_createEntityManager($metadataDriver);
  122. $cmf = $this->_createClassMetadataFactory($em, $type);
  123. $metadata = $cmf->getAllMetadata();
  124. $this->assertEquals(1, count($metadata));
  125. $class = current($metadata);
  126. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\ExportedUser', $class->name);
  127. return $class;
  128. }
  129. /**
  130. * @depends testExportedMetadataCanBeReadBackIn
  131. * @param ClassMetadataInfo $class
  132. */
  133. public function testTableIsExported($class)
  134. {
  135. $this->assertEquals('cms_users', $class->table['name']);
  136. return $class;
  137. }
  138. /**
  139. * @depends testTableIsExported
  140. * @param ClassMetadataInfo $class
  141. */
  142. public function testTypeIsExported($class)
  143. {
  144. $this->assertFalse($class->isMappedSuperclass);
  145. return $class;
  146. }
  147. /**
  148. * @depends testTypeIsExported
  149. * @param ClassMetadataInfo $class
  150. */
  151. public function testIdentifierIsExported($class)
  152. {
  153. $this->assertEquals(ClassMetadataInfo::GENERATOR_TYPE_IDENTITY, $class->generatorType);
  154. $this->assertEquals(array('id'), $class->identifier);
  155. $this->assertTrue(isset($class->fieldMappings['id']['id']) && $class->fieldMappings['id']['id'] === true);
  156. return $class;
  157. }
  158. /**
  159. * @depends testIdentifierIsExported
  160. * @param ClassMetadataInfo $class
  161. */
  162. public function testFieldsAreExported($class)
  163. {
  164. $this->assertTrue(isset($class->fieldMappings['id']['id']) && $class->fieldMappings['id']['id'] === true);
  165. $this->assertEquals('id', $class->fieldMappings['id']['fieldName']);
  166. $this->assertEquals('integer', $class->fieldMappings['id']['type']);
  167. $this->assertEquals('id', $class->fieldMappings['id']['columnName']);
  168. $this->assertEquals('name', $class->fieldMappings['name']['fieldName']);
  169. $this->assertEquals('string', $class->fieldMappings['name']['type']);
  170. $this->assertEquals(50, $class->fieldMappings['name']['length']);
  171. $this->assertEquals('name', $class->fieldMappings['name']['columnName']);
  172. $this->assertEquals('email', $class->fieldMappings['email']['fieldName']);
  173. $this->assertEquals('string', $class->fieldMappings['email']['type']);
  174. $this->assertEquals('user_email', $class->fieldMappings['email']['columnName']);
  175. $this->assertEquals('CHAR(32) NOT NULL', $class->fieldMappings['email']['columnDefinition']);
  176. return $class;
  177. }
  178. /**
  179. * @depends testFieldsAreExported
  180. * @param ClassMetadataInfo $class
  181. */
  182. public function testOneToOneAssociationsAreExported($class)
  183. {
  184. $this->assertTrue(isset($class->associationMappings['address']));
  185. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Address', $class->associationMappings['address']['targetEntity']);
  186. $this->assertEquals('address_id', $class->associationMappings['address']['joinColumns'][0]['name']);
  187. $this->assertEquals('id', $class->associationMappings['address']['joinColumns'][0]['referencedColumnName']);
  188. $this->assertEquals('CASCADE', $class->associationMappings['address']['joinColumns'][0]['onDelete']);
  189. $this->assertTrue($class->associationMappings['address']['isCascadeRemove']);
  190. $this->assertTrue($class->associationMappings['address']['isCascadePersist']);
  191. $this->assertFalse($class->associationMappings['address']['isCascadeRefresh']);
  192. $this->assertFalse($class->associationMappings['address']['isCascadeMerge']);
  193. $this->assertFalse($class->associationMappings['address']['isCascadeDetach']);
  194. $this->assertTrue($class->associationMappings['address']['orphanRemoval']);
  195. return $class;
  196. }
  197. /**
  198. * @depends testFieldsAreExported
  199. */
  200. public function testManyToOneAssociationsAreExported($class)
  201. {
  202. $this->assertTrue(isset($class->associationMappings['mainGroup']));
  203. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Group', $class->associationMappings['mainGroup']['targetEntity']);
  204. }
  205. /**
  206. * @depends testOneToOneAssociationsAreExported
  207. * @param ClassMetadataInfo $class
  208. */
  209. public function testOneToManyAssociationsAreExported($class)
  210. {
  211. $this->assertTrue(isset($class->associationMappings['phonenumbers']));
  212. //$this->assertInstanceOf('Doctrine\ORM\Mapping\OneToManyMapping', $class->associationMappings['phonenumbers']);
  213. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Phonenumber', $class->associationMappings['phonenumbers']['targetEntity']);
  214. $this->assertEquals('user', $class->associationMappings['phonenumbers']['mappedBy']);
  215. $this->assertEquals(array('number' => 'ASC'), $class->associationMappings['phonenumbers']['orderBy']);
  216. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeRemove']);
  217. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadePersist']);
  218. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeRefresh']);
  219. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeMerge']);
  220. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeDetach']);
  221. $this->assertTrue($class->associationMappings['phonenumbers']['orphanRemoval']);
  222. return $class;
  223. }
  224. /**
  225. * @depends testOneToManyAssociationsAreExported
  226. * @param ClassMetadataInfo $metadata
  227. */
  228. public function testManyToManyAssociationsAreExported($class)
  229. {
  230. $this->assertTrue(isset($class->associationMappings['groups']));
  231. //$this->assertInstanceOf('Doctrine\ORM\Mapping\ManyToManyMapping', $class->associationMappings['groups']);
  232. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Group', $class->associationMappings['groups']['targetEntity']);
  233. $this->assertEquals('cms_users_groups', $class->associationMappings['groups']['joinTable']['name']);
  234. $this->assertEquals('user_id', $class->associationMappings['groups']['joinTable']['joinColumns'][0]['name']);
  235. $this->assertEquals('id', $class->associationMappings['groups']['joinTable']['joinColumns'][0]['referencedColumnName']);
  236. $this->assertEquals('group_id', $class->associationMappings['groups']['joinTable']['inverseJoinColumns'][0]['name']);
  237. $this->assertEquals('id', $class->associationMappings['groups']['joinTable']['inverseJoinColumns'][0]['referencedColumnName']);
  238. $this->assertEquals('INT NULL', $class->associationMappings['groups']['joinTable']['inverseJoinColumns'][0]['columnDefinition']);
  239. $this->assertTrue($class->associationMappings['groups']['isCascadeRemove']);
  240. $this->assertTrue($class->associationMappings['groups']['isCascadePersist']);
  241. $this->assertTrue($class->associationMappings['groups']['isCascadeRefresh']);
  242. $this->assertTrue($class->associationMappings['groups']['isCascadeMerge']);
  243. $this->assertTrue($class->associationMappings['groups']['isCascadeDetach']);
  244. return $class;
  245. }
  246. /**
  247. * @depends testManyToManyAssociationsAreExported
  248. * @param ClassMetadataInfo $class
  249. */
  250. public function testLifecycleCallbacksAreExported($class)
  251. {
  252. $this->assertTrue(isset($class->lifecycleCallbacks['prePersist']));
  253. $this->assertEquals(2, count($class->lifecycleCallbacks['prePersist']));
  254. $this->assertEquals('doStuffOnPrePersist', $class->lifecycleCallbacks['prePersist'][0]);
  255. $this->assertEquals('doOtherStuffOnPrePersistToo', $class->lifecycleCallbacks['prePersist'][1]);
  256. $this->assertTrue(isset($class->lifecycleCallbacks['postPersist']));
  257. $this->assertEquals(1, count($class->lifecycleCallbacks['postPersist']));
  258. $this->assertEquals('doStuffOnPostPersist', $class->lifecycleCallbacks['postPersist'][0]);
  259. return $class;
  260. }
  261. /**
  262. * @depends testLifecycleCallbacksAreExported
  263. * @param ClassMetadataInfo $class
  264. */
  265. public function testCascadeIsExported($class)
  266. {
  267. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadePersist']);
  268. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeMerge']);
  269. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeRemove']);
  270. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeRefresh']);
  271. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeDetach']);
  272. $this->assertTrue($class->associationMappings['phonenumbers']['orphanRemoval']);
  273. return $class;
  274. }
  275. /**
  276. * @depends testCascadeIsExported
  277. * @param ClassMetadataInfo $class
  278. */
  279. public function testInversedByIsExported($class)
  280. {
  281. $this->assertEquals('user', $class->associationMappings['address']['inversedBy']);
  282. }
  283. /**
  284. * @depends testExportDirectoryAndFilesAreCreated
  285. */
  286. public function testCascadeAllCollapsed()
  287. {
  288. $type = $this->_getType();
  289. if ($type == 'xml') {
  290. $xml = simplexml_load_file(__DIR__ . '/export/'.$type.'/Doctrine.Tests.ORM.Tools.Export.ExportedUser.dcm.xml');
  291. $xml->registerXPathNamespace("d", "http://doctrine-project.org/schemas/orm/doctrine-mapping");
  292. $nodes = $xml->xpath("/d:doctrine-mapping/d:entity/d:one-to-many[@field='interests']/d:cascade/d:*");
  293. $this->assertEquals(1, count($nodes));
  294. $this->assertEquals('cascade-all', $nodes[0]->getName());
  295. } elseif ($type == 'yaml') {
  296. $yaml = new \Symfony\Component\Yaml\Parser();
  297. $value = $yaml->parse(file_get_contents(__DIR__ . '/export/'.$type.'/Doctrine.Tests.ORM.Tools.Export.ExportedUser.dcm.yml'));
  298. $this->assertTrue(isset($value['Doctrine\Tests\ORM\Tools\Export\ExportedUser']['oneToMany']['interests']['cascade']));
  299. $this->assertEquals(1, count($value['Doctrine\Tests\ORM\Tools\Export\ExportedUser']['oneToMany']['interests']['cascade']));
  300. $this->assertEquals('all', $value['Doctrine\Tests\ORM\Tools\Export\ExportedUser']['oneToMany']['interests']['cascade'][0]);
  301. } else {
  302. $this->markTestSkipped('Test aviable only for '.$type.' dirver');
  303. }
  304. }
  305. public function __destruct()
  306. {
  307. # $this->_deleteDirectory(__DIR__ . '/export/'.$this->_getType());
  308. }
  309. protected function _deleteDirectory($path)
  310. {
  311. if (is_file($path)) {
  312. return unlink($path);
  313. } else if (is_dir($path)) {
  314. $files = glob(rtrim($path,'/').'/*');
  315. foreach ($files as $file){
  316. $this->_deleteDirectory($file);
  317. }
  318. return rmdir($path);
  319. }
  320. }
  321. }
  322. class Address
  323. {
  324. }
  325. class Phonenumber
  326. {
  327. }
  328. class Group
  329. {
  330. }