O que causa o seguinte erro: Aviso: deslocamento ilegal de cadeia 'is_in_stock'… AdvancedInventory.php na linha 87

8

Durante o desenvolvimento do módulo, escrevi um plug-in que modifica a coleção de opções do produto antes de ser carregada (adiciona um campo de descrição). Aqui está:

etc / di.xml

<type name="Magento\Catalog\Model\ResourceModel\Product\Option\Collection">
    <plugin name="addOptionDescription" type="Vendor\Module\Plugin\Product\Option\Collection" sortOrder="10" disabled="false"/>
</type>

Código:

<?php
namespace Vendor\Module\Plugin\Product\Option;

use Vendor\Module\Model\OptionDescription;
use Magento\Catalog\Model\ResourceModel\Product\Option\Collection as OptionCollection;

class Collection
{
    /**
     * @var \Vendor\Module\Helper\Data
     */
    protected $helper;

    public function __construct(
        \Vendor\Module\Helper\Data $helper
    ) {
        $this->helper = $helper;
    }

    /**
     * @param OptionCollection $subject
     * @param bool $printQuery
     * @param bool $logQuery
     * @return array
     */
    public function beforeLoad($subject, $printQuery = false, $logQuery = false)
    {
        if (!$subject->isLoaded()) {
            $this->addDescriptionToResult($subject);
        }

        return [$printQuery, $logQuery];
    }

    /**
     * Add description to result
     *
     * If yo get error message "Warning: Illegal string offset 'is_in_stock' ... "
     * @see http://devdocs.magento.com/guides/v2.0/install-gde/trouble/php/tshoot_opcache.html
     *
     * @param OptionCollection $collection
     * @return OptionCollection $collection
     */
    private function addDescriptionToResult($collection)
    {
        $tableName = OptionDescription::TABLE_NAME;
        $joinDescriptionExpr = 'main_table.unique_option_id = option_description.unique_option_id AND option_description.store_id = 0';

        $collection->getSelect()->joinLeft(
            ['option_description' => $tableName],
            $joinDescriptionExpr,
            ['description' => 'description']
        );

        return $collection;
    }

    /**
     * Resolve current store id
     *
     * @return int
     */
    protected function getStoreId()
    {
        return $this->helper->resolveCurrentStoreId();
    }
}

Tudo parece estar bem, mas ... Quando tento carregar a página de edição do produto existente (no back-end), vejo o seguinte erro:

Aviso: deslocamento de seqüência ilegal 'is_in_stock' em [...] / fornecedor / magento / módulo-catálogo-inventário / Ui / DataProvider / Produto / Formulário / Modificador / AdvancedInventory.php na linha 87

Caso eu faça alterações, conforme indicado nos documentos (definido opcache.save_comments = 1dentro do meu php-fpm config) tudo funciona bem. Mas não consigo entender, qual código causa o erro acima e como posso evitá-lo sem modificações na configuração?

Siarhey Uchukhlebau
fonte

Respostas:

2

O ExtensionAttributesFactory(e não apenas ) usa os dockocks para determinar "coisas". (ainda não tenho certeza do que exatamente).
Se você usar o cache do OP, isso significa que seus arquivos php serão armazenados em cache, minificados e provavelmente sofrerão outras modificações.
Por padrão, o opcache não salva os comentários na versão minificada, portanto $methodDocBlock = $methodReflection->getDocComment();retornará nulle não há como descobrir metadados sobre os métodos em uma determinada interface.

Eu sei que não é uma resposta completa, mas a ideia está aqui. O Magento usa os dockblocks para descobrir metadados sobre métodos, então você precisa mantê-los.

Marius
fonte
Obrigado pela sua resposta. Eu acho que isso significa que não posso evitar esse erro sem modificações na configuração.
Siarhey Uchukhlebau