taxClassId are not saved with the rest of the productNot all products are showing upProducts are not shown when update the product category?products added to category not savedMagento cron jobs are not scheduling in the cron_schedule tableREST API Not saving products Magento2Cron jobs are not executingMagento transactional emails are not being sent & cron jobs are not workingEmails are not sendingProducts are not shown on product detailed pageNot enough data in ProductCollectionFactory, how can I get the rest?

Why is the BSI not using powers of two?

How could a scammer know the apps on my phone / iTunes account?

A sequence that has integer values for prime indexes only:

Gravity magic - How does it work?

Does Mathematica reuse previous computations?

Can I use USB data pins as power source

Should we release the security issues we found in our product as CVE or we can just update those on weekly release notes?

My adviser wants to be the first author

Use of undefined constant bloginfo

Did Ender ever learn that he killed Stilson and/or Bonzo?

Sailing the cryptic seas

What is this large pipe coming out of my roof?

how to draw discrete time diagram in tikz

What options are left, if Britain cannot decide?

Most cost effective thermostat setting: consistent temperature vs. lowest temperature possible

Declaring defaulted assignment operator as constexpr: which compiler is right?

Recruiter wants very extensive technical details about all of my previous work

How to deal with taxi scam when on vacation?

Unexpected result from ArcLength

Have researchers managed to "reverse time"? If so, what does that mean for physics?

Do the common programs (for example: "ls", "cat") in Linux and BSD come from the same source code?

Brexit - No Deal Rejection

What exactly is this small puffer fish doing and how did it manage to accomplish such a feat?

Employee lack of ownership



taxClassId are not saved with the rest of the product


Not all products are showing upProducts are not shown when update the product category?products added to category not savedMagento cron jobs are not scheduling in the cron_schedule tableREST API Not saving products Magento2Cron jobs are not executingMagento transactional emails are not being sent & cron jobs are not workingEmails are not sendingProducts are not shown on product detailed pageNot enough data in ProductCollectionFactory, how can I get the rest?













0















I'm trying to update some attributes of my product by a cron to avoid common mistakes. The code causing me trouble is executed in a loop:



foreach ($storesIds as $storeId) 
$this->storeEmulation->startEnvironmentEmulation($storeId);
$fixed = $this->doExecute($storeId);
$this->storeEmulation->stopEnvironmentEmulation();



The "doExecute method" code is simplified here, tests are done before to avoid to save a product for nothing, here is how I'm saving a product:



$searchCriteria = $this->searchCriteriaBuilder->create();
$products = $this->productRepository->getList($searchCriteria)->getItems();

// [...]

foreach ($products as $product)

// [...]

$fixes[] = ['visibility' => ['from' => $product->getVisibility(), 'to' => $expectedVisibility]];
$product->setStatus($expectedVisibility);

$fixes[] = ['taxClassId' => ['from' => $product->getTaxClassId(), 'to' => $expectedTaxClassId]];
$product->setTaxClassId($expectedTaxClassId);

try
$this->productRepository->save($product);
$this->logger->notice('A product was fixed', [
'sku' => $product->getSku(),
'storeId' => $store->getId(),
'fixes' => $fixes
]);
catch (Exception $e)
$this->logger->error('A product can't be fixed', [
'sku' => $product->getSku(),
'storeId' => $store->getId(),
'fixes' => $fixes
]);




I can see in the logs that on the first fetch the visibility is fixed. But the taxClassId is not changing:



[2019-03-15 22:49:57] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
[2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["visibility":"from":"2","to":1,"taxClassId":"from":"8","to":"2"] []
[2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []

[2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
[2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []
[2019-03-15 22:50:28] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []


Any idea where am I wrong?



Thanks for your help!









share







New contributor




JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
























    0















    I'm trying to update some attributes of my product by a cron to avoid common mistakes. The code causing me trouble is executed in a loop:



    foreach ($storesIds as $storeId) 
    $this->storeEmulation->startEnvironmentEmulation($storeId);
    $fixed = $this->doExecute($storeId);
    $this->storeEmulation->stopEnvironmentEmulation();



    The "doExecute method" code is simplified here, tests are done before to avoid to save a product for nothing, here is how I'm saving a product:



    $searchCriteria = $this->searchCriteriaBuilder->create();
    $products = $this->productRepository->getList($searchCriteria)->getItems();

    // [...]

    foreach ($products as $product)

    // [...]

    $fixes[] = ['visibility' => ['from' => $product->getVisibility(), 'to' => $expectedVisibility]];
    $product->setStatus($expectedVisibility);

    $fixes[] = ['taxClassId' => ['from' => $product->getTaxClassId(), 'to' => $expectedTaxClassId]];
    $product->setTaxClassId($expectedTaxClassId);

    try
    $this->productRepository->save($product);
    $this->logger->notice('A product was fixed', [
    'sku' => $product->getSku(),
    'storeId' => $store->getId(),
    'fixes' => $fixes
    ]);
    catch (Exception $e)
    $this->logger->error('A product can't be fixed', [
    'sku' => $product->getSku(),
    'storeId' => $store->getId(),
    'fixes' => $fixes
    ]);




    I can see in the logs that on the first fetch the visibility is fixed. But the taxClassId is not changing:



    [2019-03-15 22:49:57] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
    [2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["visibility":"from":"2","to":1,"taxClassId":"from":"8","to":"2"] []
    [2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []

    [2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
    [2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []
    [2019-03-15 22:50:28] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []


    Any idea where am I wrong?



    Thanks for your help!









    share







    New contributor




    JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.






















      0












      0








      0








      I'm trying to update some attributes of my product by a cron to avoid common mistakes. The code causing me trouble is executed in a loop:



      foreach ($storesIds as $storeId) 
      $this->storeEmulation->startEnvironmentEmulation($storeId);
      $fixed = $this->doExecute($storeId);
      $this->storeEmulation->stopEnvironmentEmulation();



      The "doExecute method" code is simplified here, tests are done before to avoid to save a product for nothing, here is how I'm saving a product:



      $searchCriteria = $this->searchCriteriaBuilder->create();
      $products = $this->productRepository->getList($searchCriteria)->getItems();

      // [...]

      foreach ($products as $product)

      // [...]

      $fixes[] = ['visibility' => ['from' => $product->getVisibility(), 'to' => $expectedVisibility]];
      $product->setStatus($expectedVisibility);

      $fixes[] = ['taxClassId' => ['from' => $product->getTaxClassId(), 'to' => $expectedTaxClassId]];
      $product->setTaxClassId($expectedTaxClassId);

      try
      $this->productRepository->save($product);
      $this->logger->notice('A product was fixed', [
      'sku' => $product->getSku(),
      'storeId' => $store->getId(),
      'fixes' => $fixes
      ]);
      catch (Exception $e)
      $this->logger->error('A product can't be fixed', [
      'sku' => $product->getSku(),
      'storeId' => $store->getId(),
      'fixes' => $fixes
      ]);




      I can see in the logs that on the first fetch the visibility is fixed. But the taxClassId is not changing:



      [2019-03-15 22:49:57] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
      [2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["visibility":"from":"2","to":1,"taxClassId":"from":"8","to":"2"] []
      [2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []

      [2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
      [2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []
      [2019-03-15 22:50:28] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []


      Any idea where am I wrong?



      Thanks for your help!









      share







      New contributor




      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.












      I'm trying to update some attributes of my product by a cron to avoid common mistakes. The code causing me trouble is executed in a loop:



      foreach ($storesIds as $storeId) 
      $this->storeEmulation->startEnvironmentEmulation($storeId);
      $fixed = $this->doExecute($storeId);
      $this->storeEmulation->stopEnvironmentEmulation();



      The "doExecute method" code is simplified here, tests are done before to avoid to save a product for nothing, here is how I'm saving a product:



      $searchCriteria = $this->searchCriteriaBuilder->create();
      $products = $this->productRepository->getList($searchCriteria)->getItems();

      // [...]

      foreach ($products as $product)

      // [...]

      $fixes[] = ['visibility' => ['from' => $product->getVisibility(), 'to' => $expectedVisibility]];
      $product->setStatus($expectedVisibility);

      $fixes[] = ['taxClassId' => ['from' => $product->getTaxClassId(), 'to' => $expectedTaxClassId]];
      $product->setTaxClassId($expectedTaxClassId);

      try
      $this->productRepository->save($product);
      $this->logger->notice('A product was fixed', [
      'sku' => $product->getSku(),
      'storeId' => $store->getId(),
      'fixes' => $fixes
      ]);
      catch (Exception $e)
      $this->logger->error('A product can't be fixed', [
      'sku' => $product->getSku(),
      'storeId' => $store->getId(),
      'fixes' => $fixes
      ]);




      I can see in the logs that on the first fetch the visibility is fixed. But the taxClassId is not changing:



      [2019-03-15 22:49:57] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
      [2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["visibility":"from":"2","to":1,"taxClassId":"from":"8","to":"2"] []
      [2019-03-15 22:49:58] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []

      [2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"107","storeId":"8","fixes":["taxClassId":"from":"0","to":"2"] []
      [2019-03-15 22:50:27] FixerLogger.NOTICE: A product was fixed "sku":"018-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []
      [2019-03-15 22:50:28] FixerLogger.NOTICE: A product was fixed "sku":"109-K","storeId":"8","fixes":["taxClassId":"from":"8","to":"2"] []


      Any idea where am I wrong?



      Thanks for your help!







      products cron repository taxes environment-emulation





      share







      New contributor




      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.










      share







      New contributor




      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.








      share



      share






      New contributor




      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 5 mins ago









      JeremyCJeremyC

      12




      12




      New contributor




      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      JeremyC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




















          0






          active

          oldest

          votes











          Your Answer








          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "479"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );






          JeremyC is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmagento.stackexchange.com%2fquestions%2f266147%2ftaxclassid-are-not-saved-with-the-rest-of-the-product%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          JeremyC is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          JeremyC is a new contributor. Be nice, and check out our Code of Conduct.












          JeremyC is a new contributor. Be nice, and check out our Code of Conduct.











          JeremyC is a new contributor. Be nice, and check out our Code of Conduct.














          Thanks for contributing an answer to Magento Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmagento.stackexchange.com%2fquestions%2f266147%2ftaxclassid-are-not-saved-with-the-rest-of-the-product%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Magento 2 duplicate PHPSESSID cookie when using session_start() in custom php scriptMagento 2: User cant logged in into to account page, no error showing!Magento duplicate on subdomainGrabbing storeview from cookie (after using language selector)How do I run php custom script on magento2Magento 2: Include PHP script in headerSession lock after using Cm_RedisSessionscript php to update stockMagento set cookie popupMagento 2 session id cookie - where to find it?How to import Configurable product from csv with custom attributes using php scriptMagento 2 run custom PHP script

          Can not update quote_id field of “quote_item” table magento 2Magento 2.1 - We can't remove the item. (Shopping Cart doesnt allow us to remove items before becomes empty)Add value for custom quote item attribute using REST apiREST API endpoint v1/carts/cartId/items always returns error messageCorrect way to save entries to databaseHow to remove all associated quote objects of a customer completelyMagento 2 - Save value from custom input field to quote_itemGet quote_item data using quote id and product id filter in Magento 2How to set additional data to quote_item table from controller in Magento 2?What is the purpose of additional_data column in quote_item table in magento2Set Custom Price to Quote item magento2 from controller

          How to solve knockout JS error in Magento 2 Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?(Magento2) knockout.js:3012 Uncaught ReferenceError: Unable to process bindingUnable to process binding Knockout.js magento 2Cannot read property `scopeLabel` of undefined on Product Detail PageCan't get Customer Data on frontend in Magento 2Magento2 Order Summary - unable to process bindingKO templates are not loading in Magento 2.1 applicationgetting knockout js error magento 2Product grid not load -— Unable to process binding Knockout.js magento 2Product form not loaded in magento2Uncaught ReferenceError: Unable to process binding “if: function()return (isShowLegend()) ” magento 2