ProxyReferenceRepository.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. declare(strict_types=1);
  3. namespace Doctrine\Common\DataFixtures;
  4. use function file_exists;
  5. use function file_get_contents;
  6. use function file_put_contents;
  7. use function get_class;
  8. use function serialize;
  9. use function substr;
  10. use function unserialize;
  11. /**
  12. * Proxy reference repository
  13. *
  14. * Allow data fixture references and identities to be persisted when cached data fixtures
  15. * are pre-loaded, for example, by LiipFunctionalTestBundle\Test\WebTestCase loadFixtures().
  16. */
  17. class ProxyReferenceRepository extends ReferenceRepository
  18. {
  19. /**
  20. * Get real class name of a reference that could be a proxy
  21. *
  22. * @param string $className Class name of reference object
  23. *
  24. * @return string
  25. */
  26. protected function getRealClass($className)
  27. {
  28. if (substr($className, -5) === 'Proxy') {
  29. return substr($className, 0, -5);
  30. }
  31. return $className;
  32. }
  33. /**
  34. * Serialize reference repository
  35. *
  36. * @return string
  37. */
  38. public function serialize()
  39. {
  40. $unitOfWork = $this->getManager()->getUnitOfWork();
  41. $simpleReferences = [];
  42. foreach ($this->getReferences() as $name => $reference) {
  43. $className = $this->getRealClass(get_class($reference));
  44. $simpleReferences[$name] = [$className, $this->getIdentifier($reference, $unitOfWork)];
  45. }
  46. return serialize([
  47. 'references' => $simpleReferences,
  48. 'identities' => $this->getIdentities(),
  49. ]);
  50. }
  51. /**
  52. * Unserialize reference repository
  53. *
  54. * @param string $serializedData Serialized data
  55. */
  56. public function unserialize($serializedData)
  57. {
  58. $repositoryData = unserialize($serializedData);
  59. $references = $repositoryData['references'];
  60. foreach ($references as $name => $proxyReference) {
  61. $this->setReference(
  62. $name,
  63. $this->getManager()->getReference(
  64. $proxyReference[0], // entity class name
  65. $proxyReference[1] // identifiers
  66. )
  67. );
  68. }
  69. $identities = $repositoryData['identities'];
  70. foreach ($identities as $name => $identity) {
  71. $this->setReferenceIdentity($name, $identity);
  72. }
  73. }
  74. /**
  75. * Load data fixture reference repository
  76. *
  77. * @param string $baseCacheName Base cache name
  78. *
  79. * @return bool
  80. */
  81. public function load($baseCacheName)
  82. {
  83. $filename = $baseCacheName . '.ser';
  84. if (! file_exists($filename)) {
  85. return false;
  86. }
  87. $serializedData = file_get_contents($filename);
  88. if ($serializedData === false) {
  89. return false;
  90. }
  91. $this->unserialize($serializedData);
  92. return true;
  93. }
  94. /**
  95. * Save data fixture reference repository
  96. *
  97. * @param string $baseCacheName Base cache name
  98. */
  99. public function save($baseCacheName)
  100. {
  101. $serializedData = $this->serialize();
  102. file_put_contents($baseCacheName . '.ser', $serializedData);
  103. }
  104. }