PageRenderTime 65ms CodeModel.GetById 33ms RepoModel.GetById 1ms app.codeStats 0ms

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

https://bitbucket.org/dudesl/pyresys
PHP | 349 lines | 228 code | 44 blank | 77 comment | 7 complexity | 02975bd560e25798b4e45ccc619c555d MD5 | raw file
Possible License(s): BSD-2-Clause, Apache-2.0, LGPL-2.1, LGPL-3.0, BSD-3-Clause
  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' => 'PHPDriver',
  64. 'annotation' => 'AnnotationDriver',
  65. 'xml' => 'XmlDriver',
  66. 'yaml' => 'YamlDriver',
  67. );
  68. $this->assertArrayHasKey($type, $mappingDriver, "There is no metadata driver for the type '" . $type . "'.");
  69. $driverName = $mappingDriver[$type];
  70. $class = 'Doctrine\ORM\Mapping\Driver\\' . $driverName;
  71. if ($type === 'annotation') {
  72. $driver = $this->createAnnotationDriver(array($path));
  73. } else {
  74. $driver = new $class($path);
  75. }
  76. return $driver;
  77. }
  78. protected function _createClassMetadataFactory($em, $type)
  79. {
  80. if ($type === 'annotation') {
  81. $factory = new ClassMetadataFactory();
  82. } else {
  83. $factory = new DisconnectedClassMetadataFactory();
  84. }
  85. $factory->setEntityManager($em);
  86. return $factory;
  87. }
  88. public function testExportDirectoryAndFilesAreCreated()
  89. {
  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. $exporter->setEntityGenerator($entityGenerator);
  103. }
  104. $this->_extension = $exporter->getExtension();
  105. $exporter->setMetadata($metadata);
  106. $exporter->export();
  107. if ($type == 'annotation') {
  108. $this->assertTrue(file_exists(__DIR__ . '/export/' . $type . '/'.str_replace('\\', '/', 'Doctrine\Tests\ORM\Tools\Export\ExportedUser').$this->_extension));
  109. } else {
  110. $this->assertTrue(file_exists(__DIR__ . '/export/' . $type . '/Doctrine.Tests.ORM.Tools.Export.ExportedUser'.$this->_extension));
  111. }
  112. }
  113. /**
  114. * @depends testExportDirectoryAndFilesAreCreated
  115. */
  116. public function testExportedMetadataCanBeReadBackIn()
  117. {
  118. $type = $this->_getType();
  119. $metadataDriver = $this->_createMetadataDriver($type, __DIR__ . '/export/' . $type);
  120. $em = $this->_createEntityManager($metadataDriver);
  121. $cmf = $this->_createClassMetadataFactory($em, $type);
  122. $metadata = $cmf->getAllMetadata();
  123. $class = current($metadata);
  124. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\ExportedUser', $class->name);
  125. return $class;
  126. }
  127. /**
  128. * @depends testExportedMetadataCanBeReadBackIn
  129. * @param ClassMetadataInfo $class
  130. */
  131. public function testTableIsExported($class)
  132. {
  133. $this->assertEquals('cms_users', $class->table['name']);
  134. return $class;
  135. }
  136. /**
  137. * @depends testTableIsExported
  138. * @param ClassMetadataInfo $class
  139. */
  140. public function testTypeIsExported($class)
  141. {
  142. $this->assertFalse($class->isMappedSuperclass);
  143. return $class;
  144. }
  145. /**
  146. * @depends testTypeIsExported
  147. * @param ClassMetadataInfo $class
  148. */
  149. public function testIdentifierIsExported($class)
  150. {
  151. $this->assertEquals(ClassMetadataInfo::GENERATOR_TYPE_IDENTITY, $class->generatorType);
  152. $this->assertEquals(array('id'), $class->identifier);
  153. $this->assertTrue(isset($class->fieldMappings['id']['id']) && $class->fieldMappings['id']['id'] === true);
  154. return $class;
  155. }
  156. /**
  157. * @depends testIdentifierIsExported
  158. * @param ClassMetadataInfo $class
  159. */
  160. public function testFieldsAreExported($class)
  161. {
  162. $this->assertTrue(isset($class->fieldMappings['id']['id']) && $class->fieldMappings['id']['id'] === true);
  163. $this->assertEquals('id', $class->fieldMappings['id']['fieldName']);
  164. $this->assertEquals('integer', $class->fieldMappings['id']['type']);
  165. $this->assertEquals('id', $class->fieldMappings['id']['columnName']);
  166. $this->assertEquals('name', $class->fieldMappings['name']['fieldName']);
  167. $this->assertEquals('string', $class->fieldMappings['name']['type']);
  168. $this->assertEquals(50, $class->fieldMappings['name']['length']);
  169. $this->assertEquals('name', $class->fieldMappings['name']['columnName']);
  170. $this->assertEquals('email', $class->fieldMappings['email']['fieldName']);
  171. $this->assertEquals('string', $class->fieldMappings['email']['type']);
  172. $this->assertEquals('user_email', $class->fieldMappings['email']['columnName']);
  173. $this->assertEquals('CHAR(32) NOT NULL', $class->fieldMappings['email']['columnDefinition']);
  174. return $class;
  175. }
  176. /**
  177. * @depends testFieldsAreExported
  178. * @param ClassMetadataInfo $class
  179. */
  180. public function testOneToOneAssociationsAreExported($class)
  181. {
  182. $this->assertTrue(isset($class->associationMappings['address']));
  183. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Address', $class->associationMappings['address']['targetEntity']);
  184. $this->assertEquals('address_id', $class->associationMappings['address']['joinColumns'][0]['name']);
  185. $this->assertEquals('id', $class->associationMappings['address']['joinColumns'][0]['referencedColumnName']);
  186. $this->assertEquals('CASCADE', $class->associationMappings['address']['joinColumns'][0]['onDelete']);
  187. $this->assertTrue($class->associationMappings['address']['isCascadeRemove']);
  188. $this->assertTrue($class->associationMappings['address']['isCascadePersist']);
  189. $this->assertFalse($class->associationMappings['address']['isCascadeRefresh']);
  190. $this->assertFalse($class->associationMappings['address']['isCascadeMerge']);
  191. $this->assertFalse($class->associationMappings['address']['isCascadeDetach']);
  192. $this->assertTrue($class->associationMappings['address']['orphanRemoval']);
  193. return $class;
  194. }
  195. /**
  196. * @depends testFieldsAreExported
  197. */
  198. public function testManyToOneAssociationsAreExported($class)
  199. {
  200. $this->assertTrue(isset($class->associationMappings['mainGroup']));
  201. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Group', $class->associationMappings['mainGroup']['targetEntity']);
  202. }
  203. /**
  204. * @depends testOneToOneAssociationsAreExported
  205. * @param ClassMetadataInfo $class
  206. */
  207. public function testOneToManyAssociationsAreExported($class)
  208. {
  209. $this->assertTrue(isset($class->associationMappings['phonenumbers']));
  210. //$this->assertTrue($class->associationMappings['phonenumbers'] instanceof \Doctrine\ORM\Mapping\OneToManyMapping);
  211. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Phonenumber', $class->associationMappings['phonenumbers']['targetEntity']);
  212. $this->assertEquals('user', $class->associationMappings['phonenumbers']['mappedBy']);
  213. $this->assertEquals(array('number' => 'ASC'), $class->associationMappings['phonenumbers']['orderBy']);
  214. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeRemove']);
  215. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadePersist']);
  216. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeRefresh']);
  217. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeMerge']);
  218. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeDetach']);
  219. $this->assertTrue($class->associationMappings['phonenumbers']['orphanRemoval']);
  220. return $class;
  221. }
  222. /**
  223. * @depends testOneToManyAssociationsAreExported
  224. * @param ClassMetadataInfo $metadata
  225. */
  226. public function testManyToManyAssociationsAreExported($class)
  227. {
  228. $this->assertTrue(isset($class->associationMappings['groups']));
  229. //$this->assertTrue($class->associationMappings['groups'] instanceof \Doctrine\ORM\Mapping\ManyToManyMapping);
  230. $this->assertEquals('Doctrine\Tests\ORM\Tools\Export\Group', $class->associationMappings['groups']['targetEntity']);
  231. $this->assertEquals('cms_users_groups', $class->associationMappings['groups']['joinTable']['name']);
  232. $this->assertEquals('user_id', $class->associationMappings['groups']['joinTable']['joinColumns'][0]['name']);
  233. $this->assertEquals('id', $class->associationMappings['groups']['joinTable']['joinColumns'][0]['referencedColumnName']);
  234. $this->assertEquals('group_id', $class->associationMappings['groups']['joinTable']['inverseJoinColumns'][0]['name']);
  235. $this->assertEquals('id', $class->associationMappings['groups']['joinTable']['inverseJoinColumns'][0]['referencedColumnName']);
  236. $this->assertEquals('INT NULL', $class->associationMappings['groups']['joinTable']['inverseJoinColumns'][0]['columnDefinition']);
  237. $this->assertTrue($class->associationMappings['groups']['isCascadeRemove']);
  238. $this->assertTrue($class->associationMappings['groups']['isCascadePersist']);
  239. $this->assertTrue($class->associationMappings['groups']['isCascadeRefresh']);
  240. $this->assertTrue($class->associationMappings['groups']['isCascadeMerge']);
  241. $this->assertTrue($class->associationMappings['groups']['isCascadeDetach']);
  242. return $class;
  243. }
  244. /**
  245. * @depends testManyToManyAssociationsAreExported
  246. * @param ClassMetadataInfo $class
  247. */
  248. public function testLifecycleCallbacksAreExported($class)
  249. {
  250. $this->assertTrue(isset($class->lifecycleCallbacks['prePersist']));
  251. $this->assertEquals(2, count($class->lifecycleCallbacks['prePersist']));
  252. $this->assertEquals('doStuffOnPrePersist', $class->lifecycleCallbacks['prePersist'][0]);
  253. $this->assertEquals('doOtherStuffOnPrePersistToo', $class->lifecycleCallbacks['prePersist'][1]);
  254. $this->assertTrue(isset($class->lifecycleCallbacks['postPersist']));
  255. $this->assertEquals(1, count($class->lifecycleCallbacks['postPersist']));
  256. $this->assertEquals('doStuffOnPostPersist', $class->lifecycleCallbacks['postPersist'][0]);
  257. return $class;
  258. }
  259. /**
  260. * @depends testLifecycleCallbacksAreExported
  261. * @param ClassMetadataInfo $class
  262. */
  263. public function testCascadeIsExported($class)
  264. {
  265. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadePersist']);
  266. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeMerge']);
  267. $this->assertTrue($class->associationMappings['phonenumbers']['isCascadeRemove']);
  268. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeRefresh']);
  269. $this->assertFalse($class->associationMappings['phonenumbers']['isCascadeDetach']);
  270. $this->assertTrue($class->associationMappings['phonenumbers']['orphanRemoval']);
  271. return $class;
  272. }
  273. /**
  274. * @depends testCascadeIsExported
  275. * @param ClassMetadataInfo $class
  276. */
  277. public function testInversedByIsExported($class)
  278. {
  279. $this->assertEquals('user', $class->associationMappings['address']['inversedBy']);
  280. }
  281. public function __destruct()
  282. {
  283. $type = $this->_getType();
  284. $this->_deleteDirectory(__DIR__ . '/export/'.$this->_getType());
  285. }
  286. protected function _deleteDirectory($path)
  287. {
  288. if (is_file($path)) {
  289. return unlink($path);
  290. } else if (is_dir($path)) {
  291. $files = glob(rtrim($path,'/').'/*');
  292. foreach ($files as $file){
  293. $this->_deleteDirectory($file);
  294. }
  295. return rmdir($path);
  296. }
  297. }
  298. }