/**
  * @param string $jsonString
  *
  * @return Filter[]
  */
 public static function getFiltersFromJSONString($jsonString)
 {
     return Helper::makeArrayOfObjectsFromJsonString($jsonString, ['property', 'value'], function ($rawObj) {
         $value = $rawObj->value;
         if ($value === 'null') {
             $value = null;
         }
         return new Filter($rawObj->property, $value, isset($rawObj->operator) ? $rawObj->operator : Filter::OP_EQ);
     }, 'Filter');
 }
 /**
  * Метод осуществляет выборку сущностей из менеджера сущностей, создает контент и записывает в файл
  *
  * @param \Doctrine\ORM\EntityManager $em
  * @param string $dirForGeneratedFixtures директория, в которой будут созданы файлы с фикстурами
  * @param string $className полное имя класса для создания фикстур
  * @param int $entitiesPerClass кол-во сущностей на один класс
  * @param int $entitiesPerFile кол-во сущностей в одном файле
  */
 private function generateFixtureForEntityClass(EntityManager $em, $dirForGeneratedFixtures, $className, $entitiesPerClass = self::DEFAULT_MAX_ENTITIES_COUNT, $entitiesPerFile = self::DEFAULT_ENTITIES_PER_FILE)
 {
     $metadata = $em->getClassMetadata($className);
     $countEntitiesInDB = EntityHelper::getCountOfEntities($em, $className);
     $howManyEntitiesShouldBe = min($entitiesPerClass, $countEntitiesInDB);
     $countOfFiles = ceil($howManyEntitiesShouldBe / $entitiesPerFile);
     $shortClassName = Helper::getClassNameWithoutNamespace($className);
     for ($fileNo = 0; $fileNo < $countOfFiles; $fileNo++) {
         $entities = $em->getRepository($className)->findBy([], null, $entitiesPerFile, $entitiesPerFile * $fileNo);
         $content = "{$className}:\n";
         foreach ($entities as &$entity) {
             $id = $metadata->getSingleIdReflectionProperty()->getValue($entity);
             $content .= "  entity_{$id}:\n";
             $fieldNames = $metadata->getFieldNames();
             foreach ($fieldNames as $fieldName) {
                 $fieldValue = $metadata->getFieldValue($entity, $fieldName);
                 if ($fieldValue instanceof \DateTime) {
                     $fieldValue = "'" . $fieldValue->format(self::DATETIME_FORMAT) . "'";
                 } elseif (is_string($fieldValue)) {
                     $fieldValue = str_replace("\n", '', $fieldValue);
                     /*
                      * Этот кусок написан из-за того, что кавычки (" и ') являются частью YAML, и неожиданное их появление
                      * в строковых значение рушит парсер, так что там где встречаются кавычки, мы их обрамляем на "противоположенные", т.е.
                      * если есть ", то обрамим в ';
                      * если есть ', то обрамим в ";
                      *
                      * насчет появления обоих этих кавычек пока ничего сказать не могу...
                      */
                     if (strpos($fieldValue, '"') !== false) {
                         $fieldValue = "'{$fieldValue}'";
                     } elseif (strpos($fieldValue, "'") !== false) {
                         $fieldValue = sprintf('"%s"', $fieldValue);
                     }
                     /*
                      * Вот я не знаю что это за знак такой ... но вроде так работает...
                      */
                     $fieldValue = str_replace("\n", ' ', $fieldValue);
                 }
                 /*
                  * Т.к. true и false не записываются в текстовой файл, то для них сделаем такую штуку.
                  */
                 if (is_bool($fieldValue)) {
                     $fieldValue = $fieldValue ? 'true' : 'false';
                 }
                 $content .= "    {$fieldName}: {$fieldValue}\n";
             }
         }
         $filePath = $dirForGeneratedFixtures . "/{$shortClassName}_{$fileNo}." . self::FILE_EXTENSION;
         file_put_contents($filePath, $content);
         $em->clear();
     }
 }
Exemple #3
0
 public function testMakeArrayOfObjectsWithFilteredObjectCreator()
 {
     $data = [['property' => 'id', 'value' => '2'], ['property' => 'name', 'value' => 'some']];
     $f = function ($data) {
         $obj = new \stdClass();
         if ($data->property == "name") {
             return null;
         }
         $obj->property = $data->property;
         $obj->value = $data->value;
         return $obj;
     };
     $objects = Helper::makeArrayOfObjectsFromJsonString(json_encode($data), ['property', 'value'], $f);
     $this->assertCount(1, $objects);
     $this->assertNotNull($objects[0]);
 }
Exemple #4
0
 /**
  * Производит проверку на инициализированность объекта, применяется когда некие методы не могут быть использованы,
  * если объект не был инициализирован
  *
  * @throws \Amstaffix\Common\Exception\InitializeException
  */
 protected function checkInitialization()
 {
     if (!$this->isInit) {
         throw new InitializeException(sprintf("Нельзя вызывать метод (%s) до инициализации объекта, инициализируйте объект методом init()", Helper::getCallerMethodName()), ErrCode::CALL_FORBIDDEN_METHOD_BEFORE_INIT);
     }
 }
 protected function checkIsInit()
 {
     if (!$this->isInit) {
         throw new \LogicException(sprintf("Нельзя вызывать метод (%s) до инициализации объекта, инициализируйте объект методом init()", Helper::getCallerMethodName()));
     }
 }