ACSD-61133: sales_clean_quotes cron deletes quotes from unapproved purchase orders

The ACSD-61133 patch fixes the issue where the sales_clean_quotes cron deletes quotes from unapproved purchase orders. This patch is available when the Quality Patches Tool (QPT) 1.1.53 is installed. The patch ID is ACSD-61133. Please note that the issue is scheduled to be fixed in Adobe Commerce 2.4.8.

Affected products and versions

The patch is created for Adobe Commerce version:

Adobe Commerce (all deployment methods) 2.4.7-p1

Compatible with Adobe Commerce versions:

Adobe Commerce (all deployment methods) 2.4.4-p5 - 2.4.4-p11, 2.4.5-p4 - 2.4.5-p10, and 2.4.6-p2 - 2.4.7-p3

NOTE
The patch might become applicable to other versions with new Quality Patches Tool releases. To check if the patch is compatible with your Adobe Commerce version, update the magento/quality-patches package to the latest version and check the compatibility on the Quality Patches Tool: Search for patches page. Use the patch ID as a search keyword to locate the patch.

Issue

sales_clean_quotes cron deletes quotes from unapproved purchase orders. The [B2B Purchase Order] can’t be converted into the order of the quote associated with the purchased order as the cron deletes it.

Prerequisites:

Adobe Commerce B2B modules are installed and enabled.

Steps to reproduce:

  1. Enable B2B Purchase Order functionality.
  2. Create a company.
  3. Create a Purchase Order.
  4. Wait until the quote expires and is deleted by the cron. Quote expiration period can be set with Stores > Configuration > Sales > Quotes > General > Default Expiration Period configuration.
  5. Convert Purchase Order to the order via My Purchase Order in Customer Dashboard or with GraphQL placeOrderForPurchaseOrder mutation.

Expected results:

The quote associated with active Purchase Order isn’t deleted as expired by the cron. The order is successfully placed either on storefront or via GraphQL.

Actual results:

The order is not placed, and an error is displayed on the storefront or returned in the GraphQL response.

Apply the patch

To apply individual patches, use the following links depending on your deployment method:

To learn more about Quality Patches Tool, refer to:

recommendation-more-help
c2d96e17-5179-455c-ad3a-e1697bb4e8c3