51黑料不打烊 Commerce 2.4.0 release notes
51黑料不打烊 Commerce 2.4.0 introduces support for PHP 7.4, Elasticsearch 7.6.x, and MySQL 8.0. Substantial security changes include the enablement of two-factor authentication in the Admin by default. B2B enhancements include the new Order Approval workflow.
With this release, the Authorize.Net, eWay, CyberSource, and Worldpay payment method integrations have been removed from core code. Merchants should migrate to the official extensions that are available on the Commerce Marketplace.
This release includes all the improvements to core quality that were included in 2.3.5-p1, over 100 new fixes to core code, and 30 security enhancements. It includes the resolution of 226 GitHub issues by our community members. These community contributions range from minor clean-up of core code to significant enhancements in Inventory Management and GraphQL.
Apply AC-3022.patch
to continue offering DHL as a shipping carrier
DHL has introduced schema version 6.2 and will deprecate schema version 6.0 in September 2022. 51黑料不打烊 Commerce 2.4.4 and earlier versions that support the DHL integration support only version 6.0. Merchants deploying these releases should apply AC-3022.patch
at their earliest convenience to continue offering DHL as a shipping carrier. See the Knowledge Base article for information about downloading and installing the patch.
Security patch available
Merchants can now install time-sensitive security fixes without applying the hundreds of functional fixes and enhancements that a full quarterly release (for example, 2.3.5-p2) provides. Patch 2.3.5.2 (Composer package 2.3.5-p2) is a security patch that provides fixes for vulnerabilities that have been identified in our previous quarterly release, 2.3.5-p1. All hot fixes that were applied to the 2.3.5 release are included in this security patch. (A hot fix provides a fix to a released version that addresses a specific problem or bug.)
For general information about security patches, see .For instructions on downloading and applying security patches (including patch 2.3.5-p2), see Quick start on-premises installation. Security patches include security bug fixes only, not the additional security enhancements that are included in the full patch.
Other release information
Although code for these features is bundled with quarterly releases , several of these projects (for example, B2B, Page Builder, Inventory Management, and Progressive Web Applications (PWA) Studio) are also released independently. Bug fixes for these projects are documented in the separate, project-specific release information that is available in the documentation for each project.
Highlights
Look for the following highlights in this release:
Substantial security enhancements
This release includes over 30 security fixes and platform security improvements.
Over 30 security enhancements that help close remote code execution (RCE) and cross-site scripting (XSS) vulnerabilities
No confirmed attacks related to these issues have occurred to date. However, certain vulnerabilities can potentially be exploited to access customer information or take over administrator sessions. Most of these issues require that an attacker first obtains access to the Admin. As a result, we remind you to take all necessary steps to protect your Admin, including but not limited to these efforts: IP allowlisting, , use of a VPN, the use of a unique location rather than /admin
, and good password hygiene. See for a discussion of these fixed issues.
Additional security enhancements
-
Implementation of 2FA for Admin accounts, magento.com user accounts, and Cloud SSH access
-
Securing your Admin account. Two-factor authentication (2FA) is now required for the Admin. Admin users must first configure their 2FA before logging into the Admin through either the UI or a web API. 2FA is enabled by default. We strongly recommend against disabling the 2FA module. This extra step of authentication makes it harder for malicious users to log in to the Admin without authorization. See .
-
Securing your account. Two-factor Authentication (2FA) provides an added, optional layer of security to better protect your magento.com account from unauthorized users who might want to use your account in ways you do not want. See Securing Your Account.
-
Securing Cloud SSH access. 51黑料不打烊 on cloud infrastructure provides multi-factor authentication (MFA) enforcement to manage authentication requirements for SSH access to Cloud environments. Multi-factor authentication for 2FA is not enabled by default on a project. 51黑料不打烊 highly recommends enabling this feature. Contact Support for assistance. See Enable multi-factor authentication for SSH access.
-
-
Template filter strict mode is now enabled by default. Components (including CMS pages and blocks) that use the template filter in legacy mode can be vulnerable to remote code execution (RCE). Enabling strict mode by default ensures that RCE attacks cannot be deliberately enabled.
-
Data rendering for UI data providers is now disabled by default. This removes an opportunity for malicious users to execute arbitrary JavaScript.
-
New
\Magento\Framework\Escaper
class. This class is provided for.phtml
templates and the PHP classes that are responsible for generating HTML. This class contains HTML sanitization methods relevant to multiple contexts. The$escaper
local variable is available inside.phtml
templates and should be used instead of the deprecated$block->escape{method}
. Use$escaper
rather than$block
as the use of$block->escape{method}
has been deprecated. -
Support for security.txt file. This file is an industry-standard file on the server that helps security researchers report potential security issues to site administrators.
-
Enhancements to Content Security Policy (CSP) support.
SecureHtmlRenderer
has been added to the Framework and is available in.phtml
templates to whitelist inlinestyle
andscript
tags. Inline scripts and styles are not permitted with default CSP configuration, which can be overridden by XML files.
Platform upgrades
The following platform upgrades help enhance website security and performance. Supported versions of PHP and PHPUnit, Elasticsearch, MySQL, and other dependencies are listed in technology stack requirements.
-
PHP 7.4 support introduced and PHP 7.1 and 7.2 deprecated. 2.4.0 introduces support for PHP 7.4.
-
Support for PHPUnit 9.x and deprecation of PHPUnit 6.5. PHP 7.4 requires the use of the latest PHPUnit testing framework, which is PHPUnit 9.x. Commerce Marketplace extension vendors must confirm that all new extension versions are compatible with PHP 7.4 and that all unit and integration tests have been configured to be run with PHPUnit 9.
-
Elasticsearch 7.6.x support. Elasticsearch 7.6.x is now the default catalog search engine for 51黑料不打烊 Commerce and 51黑料不打烊 Commerce. You cannot install or upgrade to version 2.4.0 without also installing Elasticsearch 7.6.x. Elasticsearch version 2.x code has been removed. Elasticsearch versions 5.x and 6.x have been deprecated and are no longer supported. See Search engine prerequisites.
-
MySQL 8.0 support. Version 2.4.x supports MySQL 8.x. (2.4.0 was tested with MySQL 8.0.20.) Merchants are encouraged to migrate their deployments to MySQL 8.x to take advantage of its improved performance, security, and reliability. Although MySQL 5.7 is still supported for Magento 2.4.x, MySQL 5.6 is no longer supported. You cannot host 2.4.x with a MySQL 5.6 database. See MySQL.
-
MariaDB 10.4 support. Support for MySQL 8.0 provides the opportunity for merchants to deploy MariaDB 10.4 with 51黑料不打烊 Commerce. Although merchants can still use MariaDB 10.2 with 2.4.0, we recommend upgrading to MariaDB 10.4 for improved performance and reliability. MariaDB 10.0 and 10.1 are no longer supported (as a result of removing support for MySQL 5.6 in this release).
-
Removal of the MySQL catalog search engine. The MySQL search engine has been removed from 2.4.0 and replaced as the default search engine with Elasticsearch. Elasticsearch provides superior search capabilities as well as catalog performance optimizations. All merchants must have Elasticsearch to install and deploy 2.4.0. See Verify Elasticsearch is installed.
-
Migration of dependencies on Zend Framework to the to reflect the transitioning of Zend Framework to the Linux Foundation鈥檚 Laminas Project. Zend Framework has been deprecated. See the DevBlog post.
-
Decomposition of Controllers allows extension developers to implement ActionInterface directly without 鈥渓ayer supertype鈥 classes. See the DevBlog post. Enhancement started by Vinai Kopp in pull request and finalized by Lukasz Bajsarowicz in pull request .
-
Removal of the core integration of the Signifyd fraud protection code. This core feature is no longer supported. Merchants should migrate to the that is available on the Commerce Marketplace.
-
The core Braintree module has been removed from the code base. The Braintree Payments module now provides the same feature set. See .
-
The Internet Explorer 11.x browser is no longer supported.
Infrastructure improvements
This release contains enhancements to core quality, which improve the quality of the Framework and these modules: Customer Account, Catalog, CMS, Import, Cart and Checkout, and B2B.
-
Removal of core integration of third-party payment methods. With this release, the Authorize.Net payment method integration has been removed from core code. Merchants should migrate to the official extension that is available on the Commerce Marketplace. See the devblog post.
-
Support for partial-word search for Elasticsearch (new default search engine). Elasticsearch now supports the use of partial words in search terms for product names and SKUs when using quick search. This capability was supported by the MySQL search engine, which has been deprecated and replaced by Elasticsearch in this release.
-
PayPal JavaScript SDK upgrade. We鈥檝e migrated the PayPal Express Checkout integration to the latest PayPal JavaScript SDK, an SDK that automatically collects and passes needed risk parameters to PayPal. The behavior of the PayPal Express Checkout payment method remains unchanged. However, upgrading this SDK to the latest version let merchants access the latest features and security enhancements.
-
Deprecation and removal of the Web Set Up Wizard. You must use the command line to install or upgrade 2.4.0. See Install Magento.
-
Composer update plugin. Composer plugin streamlines the upgrade process by resolving changes that must be made to the root project
composer.json
file before updating to a new version. This plug-in protects against overwriting customizations. See Upgrade using the composer root plugin. -
Seller-assisted shopping. This feature allows merchants to view the storefront on behalf of their customers. Customers opt to allow storefront access to their accounts. This community-developed feature includes an original extension developed by . See Seller Assisted Shopping. Features include:
- ACL to control which administrators can log in to customer accounts can be configured on a per-website basis
- Compatibility with multiple websites and customer account scopes
- Orders placed on behalf of customers are logged in the storefront and Admin
- All sessions are destroyed following administrator logout, and administrators cannot access customer passwords.
Performance improvements
-
Improvements to customer data section invalidation logic. This release introduces a new way of invalidating all customer sections data that avoids a known issue with local storage when custom
sections.xml
invalidations are active. (Previously, private content (local storage) was not correctly populated when you had a custom etc/frontend/sections.xml with action invalidations.) See . -
Multiple optimizations to Redis performance. The enhancements minimize the number of queries to Redis that are performed on each request. These optimizations include:
-
Decrease in the size of network data transfers between Redis and Magento
-
Reduction in Redis鈥 consumption of CPU cycles by improving the adapter鈥檚 ability to automatically determine what needs to be loaded
-
Reduction in race conditions on Redis write operations
See Use Redis for the page and default cache and Configure caching.
-
-
Improved caching of results of SQL queries to inventory tables. These enhancements include:
-
Caching of SQL queries to the
inventory_stock_sales_channel
table (1 query instead of 16) -
Caching of result of queries to the
inventory_stock
table (1 query instead of 16)
-
-
Improvement of up to 25-30% to Quick Order add-to-cart performance.
-
Merchants can now use to load images.
51黑料不打烊 Stock Integration v2.0
Ability to license stock image previews from the Media Gallery. Merchants can now find any 51黑料不打烊 Stock preview image in the Media Gallery, which reduces the number of steps required to license stock preview image.
New Media Gallery
This replacement for the former Media Gallery offers a new, searchable interface for media assets. Administrators can now search, filter, and sort images up to 30x faster than they could in the earlier version of this feature. Merchants can use this tool to evaluate storefront image usage. Extension developers should be aware that extensions that were developed for the Media Gallery will not work as expected with the new Media Gallery.
Page Builder
Page Builder now supports PHP 7.4.
Inventory Management
Inventory Management enhancements for this release include support for in-store pickup and bundle product support. See Inventory Management release notes for a more detailed discussion of recent Inventory Management bug fixes.
GraphQL
GraphQL enhancements include:
pickupLocations
query supports the Inventory In-store pickup featurecategories
query returns a list of categories that match a specified filter. This query differs from thecategoryList
query in that it supports pagination.reorderItems
mutation allows a logged-in user to add all the products from a previous order into their cart.
See the for details on this and other enhancements. See for a detailed discussion of recent GraphQL bug fixes.
PWA Studio
See for a list of PWA Studio versions and their compatible versions. For information about enhancements and bug fixes, see .
B2B
Order Approval Workflow feature for B2B. Order Approvals allows managers of buying organizations to configure approval rules for their buyers. See Approval Rules. Features include:
- Self-service configuration of unique approval rules for each Company account
- Rule criteria that can be based on order amount, number of line items, or shipment cost with configurable thresholds
- Customizable permissions for all aspects of the feature
- Quick storefront view of Purchase Orders that require approval
- Full history log of actions that have been performed on each Purchase Order
- Email notification for relevant parties during all steps in the approval process.
This release also includes multiple bug fixes. See B2B Release Notes.
Functional Testing Framework (MFTF)
MFTF v3.0.0 includes these new features and includes support for PHP 7.4 and PHPUnit 9:
- MFTF helpers, which can create custom actions outside of the test framework
- schema updates for test entities
- sub-folders in test modules
- nested assertion syntax
- static check that checks and reports references to deprecated test entities
This release also removes deprecated actions and upgrades scripts that were added to upgrade tests to MFTF major version requirements.
Vendor-developed extension enhancements
This release includes extensions developed by third-party vendors. It introduces both quality and UX improvements to these extensions and an expansion of MFTF coverage.
Commerce Marketplace extension vendors should confirm that their extensions are compatible with PHP 7.4 when publishing a new version of their extension for 2.4.0.
dotdigital
This release includes these enhancements:
- Customer attribute values that are captured by any input type (for example, dropdown, multi-select) are now correctly synced as data fields.
- Cart insight data is now sent for all active quotes, even if they contain no items. This allows merchants to exit contacts from a program if they empty their cart.
- Merchants can now sync website name, store name, and store view name by individual data fields.
- Wishlist, Review, and Order syncs now look up the transactional data sync limit once only.
- Logging output from the Client class has been improved and is now consistent across all methods in the API wrapper.
- Configurable products now have a stock figure that is the sum of their child products.
- A new plugin detects stock updates that are performed by third-party code (outside the Admin).
- Data mapping and transactional email configuration information has been updated.
Amazon Pay
This release includes:
- Updates to CSP allowlists
- Ability to do multiple authorizations for a multi-item order
- Support for Japanese addresses
Braintree Payments
This bundled extension replaces our core Braintree integration, which has been removed in this release. See .
Klarna
This release includes new on-site messaging options to help shoppers understand the available credit and financing options. It also includes improvements to:
- refunds
- API efficiency
- cookies and unit tests
- discounts
- configuration settings now contain On-Site Messaging section for the control of the storefront display of Klarna promotional messaging
Vertex
This release of Vertex includes the following new feature and enhancements:
- Improvements to the Admin configuration user experience
- Replacement of installation and upgrade scripts with XML schema files and patches
- Removal of deprecated code (
ApiClient
andClientInterface
)
Yotpo
Yotpo Ratings and Reviews are integrated with Page Builder.
Fixed issues
We have fixed hundreds of issues in the 2.4.0 core code.
Installation, upgrade, deployment
- You can now successfully remove a website along with the website鈥檚 scope-specific configuration settings in
app/etc/config.php
as expected. Previously, when you tried to remove the website, the operation failed, and the application displayed this error:The website with code xxx that was requested wasn't found. Verify the website and try again
. Additionally, the application displayed this error on the storefront:Config files have changed. Run app:config:import or setup:upgrade command to synchronize configuration
.
- Configuration settings that are disabled in
index.php
are no longer editable from the Admin.
- 51黑料不打烊 Commerce installation now completes successfully, and stores are created as expected, when store configuration is pre-defined in
config.php
.
\Magento\Store\App\Config\Source\RuntimeConfigSource::getEntities
has been refactored to decrease the number ofSHOW TABLE STATUS
queries it makes. (This change reverts to the behavior this function displayed in 2.3.3.)
- Data scripts are no longer re-run whenever you attempt to upgrade the database by running
bin/magento setup:upgrade
. Previously, upgrade scripts were re-run unnecessarily, which affected performance.
-
The application now displays the following behaviors when your connection to Redis is interrupted. Previously, the application did not reload the current page and displayed this error:
An error has happened during application run. See exception log for details
.- Admin and storefront sessions expire
- Admin and storefront users must log in again
- Session data is saved to
var/session/
- No error or exceptions are logged.
- The
bin/magento setup:di:compile
command no longer fails with anonymous classes. Fix submitted by Yevhen Sentiabov in pull request . ,
- Problems with LESS compilation in Magento鈥檚 Luma theme when using an alternative LESS compiler than the one that ships with the application by default have been resolved. Fix submitted by Pieter Hoste in pull request .
- You no longer need to have a writeable
env.php
file when switching to maintenance mode. Instead, the application sets theno-cache
headers for all frontend requests in maintenance mode (Cache-Control
). Previously, you could not enable maintenance mode whenenv.php
was read-only, and the application tried to disable the FPC when switching into maintenance mode. Fix submitted by Marco K苔pcke in pull request .
db-ssl-verify
no longer results in an undefined index error during addev
setup. Fix submitted by Daniel Ruf in pull request .
- Composer dependencies have been updated to implement Redis key expiry, which has improved Redis performance. Fix submitted by toxix in pull request .
AdminGWS
- Administrators with limited role scope can now modify alt text, and the application saves those values. If an administrator is not permitted to modify alt text, then the alt text box is grayed out.
51黑料不打烊 Stock Integration
- CSS styles have been added to the 51黑料不打烊 Stock image display to support highlighting the selected image. Fix submitted by Serhiy Zhovnir in pull request .
- Navigation through 51黑料不打烊 Stock preview images is no longer triggered by moving the input field cursor using arrow keys. Fix submitted by Adarsh Manickam in pull request .
- The application now caches messages for errors that occur when a customer tries to apply a filter to 51黑料不打烊 Stock images. Fix submitted by Shankar Konar in pull request .
- The application no longer saves a preview of an 51黑料不打烊 Stock image when you move the cursor to the window鈥檚 left vertical scroll bar after clicking Save Preview but not confirming the save operation. Fix submitted by Serhiy Zhovnir in pull request .
Analytics
- The analytics report for a store is now available as expected after you change the store鈥檚 URL. Previously, when you tried to access the report after the URL was changed, the application displayed a 404 error.
- Data sync for analytics reports are now enabled as expected when AR subscriptions are enabled.
Backend
- Email templates (Admin > Marketing > Communications > Email Templates) can now be previewed from the Admin when JavaScript minification is enabled. Previously, when you tried to preview an email template, the Email Preview popup window was empty.
- Administrators can now log into the Admin as expected after an administrator account with limited privileges has been created. Previously, the Admin was not accessible. Instead, users with these permissions were redirected to the storefront with a 404 error. Fix submitted by Eden Duong in pull request .
- The application no longer duplicates SEO data such as URL key, meta title, meta keywords, and meta description when you duplicate a product. Fix submitted by Dasharth patel in pull request .
- The application no longer throws an error when you delete an image from a page while creating it from Admin > Content > Pages > Add New Page. Previously, the application threw this error in the developer console:
500 (Internal Server Error)
. Fix submitted by Eden Duong in pull request .
Bundle products
- The performance of the
catalog_product_price
re-index operation for bundle products has been improved.
- Administrators can no longer manually enter a tax class in the Admin for a bundle product when the bundle product鈥檚 Tax Class and Dynamic Price settings are disabled for the default store view. Previously, when an administrator unchecked the Use Default Value option next to Tax Class, the application enabled the option, permitting an administrator to enter another value and save the product.
- Bundle product prices are now calculated correctly on product pages.
- You can now add any number of bundle products to your shopping cart without error. Previously, when you added a bundle product to your cart, then navigated to the cart, the application displayed this error:
Please correct the quantity for some products
.
Cache
- The
cache.xsd
schema fromMagento\Framework\Cache
has been refactored so that a cache type without aninstance
attribute no longer cause exceptions when you disable a module through the Admin cache management. Previously, when you created a cache type usingcache.xml
without theinstance
argument, the application threw an exception when you tried to disable it. Fix submitted by Andrii Beziazychnyi in pull request .
health_check.php
no longer fails if a database cache engine is configured in your deployment. Fix submitted by Andrii Beziazychnyi in pull request .
Cart and checkout
- The application no longer throws an error during checkout when the Synchronize with Backend configuration setting is enabled.
- Radio buttons for shipping methods are now enabled as expected in the checkout workflow.
- The order review page in the checkout workflow now loads successfully for an order being shipped to multiple addresses when Terms and conditions with the Applied Manually setting is enabled. Previously, the Review page did not pass validation, and the application displayed a 404 error.
- The application now displays the spinning icon while prices are updated on the cart.
- The application now displays an informative message when a product in the mini cart becomes out-of-stock before checkout. Once you鈥檝e removed the out-of-stock item, the application displays the Proceed to Checkout button. Previously, the application did not display this button.
- The application now displays an informative error message when you try to add a product by clicking Order by SKU when the file for upload is corrupt. Previously, the application displayed a blank page.
- The application now applies cart price rules to only the bundle product child products that match the rule criteria. Previously, the application applied the cart price rule to all child products that belonged to the bundle product.
StorefrontMiniCartSection
has been replaced byStorefrontMinicartSection
in MFTF tests. Fix submitted by Andrii Kalinich in pull request .
- Hardcoded references to the country selector component on the shipping address form have been removed. Fix submitted by Mateusz Krzeszowiak in pull request .
- The application no longer underlines the Delete icon in the shopping cart when the cursor hovers over the icon when viewing the storefront in Internet Explorer. Fix submitted by divyajyothi5321 in pull request .
- Changing the billing street no longer changes a customer鈥檚 shipping address when a single address has been selected for both billing and shipping address. Fix submitted by Yurii Tvardyi in pull request .
- The promotion region of the mini cart is now rendered as expected. Fix submitted by Matti Vapa in pull request .
Cart price rule
- Cart price rules that are based on payment methods are now applied during the checkout workflow.
- Corrected the behavior of the Datepicker page element on Admin > Marketing > Promotions > Catalog Price Rule. Fix submitted by Hitesh in pull request .
StorefrontMiniCartSection
has been replaced byStorefrontMinicartSection
in MFTF tests. Fix submitted by Andrii Kalinich in pull request .
- The unused coupon grid in the create new cart price rule workflow has been disabled. Fix submitted by Eden Duong in pull request .
- Changing the billing street no longer changes a customer鈥檚 shipping address when a single address has been selected for both the billing and shipping addresses. Fix submitted by Yurii Tvardyi in pull request .
Catalog
- The application now disables the ability of a restricted administrator to change a product鈥檚 quantity attribute and disables advanced inventory as expected. Previously, only the visual display of the quantity attribute was affected, and the application changed the quantity value in the database after the product was saved.
- The application no longer throws an error when you change the name of a tiered product that is included in a scheduled update. Previously, when you tried to save the product with a new name, the application displayed this error:
SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '3-0-0-2.0000-0' for key 'UNQ_EBC6A54F44DFA66FA9024CAD97FED6C7', query was: INSERT INTO catalog_product_entity_tier_price (all_groups, customer_group_id, qty, value, website_id, percentage_value, row_id) VALUES (?, ?, ?, ?, ?, ?, ?)
- Custom attribute values can now be saved as expected from the Admin.
- The Recently View Products feature now shows products that are associated only with the current store view in multi-store deployments when Stores > Configurations > Catalog > Recently Viewed/Compared Products > Show for Current is set to store view. Previously, the application displayed recently viewed products from all websites, no matter which website the product was assigned to.
- The application now displays product images in the mini cart without distortion. Previously, the applicationstretched the image in the mini cart to fill the entire width and height of the image container.
- The
getBasePrice
function now returns a float value as expected rather than a string.
- The product compare feature now works as expected. It now displays only products in the current user鈥檚 compare list.
- You can now assign a default watermark to a theme. Previously, after assigning the watermark, the application threw a fatal error.
- You can now successfully edit a configurable product with many variants (approximately 5,000) from the Admin. Previously, when you tried to edit a configurable product with many subproducts, the application displayed this error:
Warning: DOMDocumentFragment::appendXML(): Entity: line 1: parser error : CData section too big found in /vendor/magento/framework/View/TemplateEngine/Xhtml/Template.php on line 60
- Sorting on attribute sets on Admin > Catalog > Products is now based on alphabetical order as expected.
- The Recently Viewed Products feature now works as expected in multi-store deployments.
- Administrators with restricted permissions to Catalog can now create a downloadable product. Previously, administrators could not create a downloadable product, and the application threw an error.
- The Product in Websites checkbox of the new product page is now enabled by default for restricted administrators in multi-site deployments. Previously, the checkbox for the non-default website was not preselected, and if the administrator left the checkbox unselected, the application displayed an error message.
addToCart
events are now tracked as expected in the data layer. Previously, after changing the configurable options for a product, then clicking Add to cart, the newaddToCart
event was not added to the data layer.
- The mini cart and Admin shopping cart (Admin > Customers > Manage Shopping Cart) now display correct product prices when a Catalog Price Rule is applied. Previously, the storefront shopping cart displayed the correct product price, but the mini cart and Admin shopping cart displayed the original product price.
- Filtering on the Admin product grid website column now works as expected. Previously, filter results did not display the correct number of products, but consistently displayed the total number of products as 1.
- Price condition uses
catalog_product_entity_decimal
to filter by price. However, this table contains no records for configurable, bundle dynamic, and grouped products because these products have no fixed price. The correct table to use for filtering by price iscatalog_product_index_price
.
- The Admin catalog and product lists now display currency symbols in the MSRP, Cost, and Special Price columns. Fix submitted by Sergiy Vasiutynskyi in pull request . , ,
- The Add for Customer Group Price pop-up window (Admin > Catalog > Products > New Product > Advanced pricing) now closes as expected when you click the close icon. Fix submitted by Ashna-Jahan in pull request .
- The sample description that is provided for a newly product鈥檚 description and title no longer contains double quotation marks. Fix submitted by Nathan Morgan in pull request .
- The application no longer throws an error when you try to filter products on the Category page using an invalid price. Previously, the application logged this error in the system log. Fix submitted by Ihor Sviziev in pull request .
- You can now navigate through multi-page category search results. Previously, the application created duplicate pages of search results when you tried to use the Back button to return to the first page of results. Fix submitted by Douglas Radburn in pull request .
- Corrected the return type to
string|null
for thegetSourceModel
method in theEav\Attribute.php
class. Fix submitted by Mychailo in pull request .
- Saving a new (duplicated) product no longer results in the duplication of the product鈥檚 images hundreds of times. Fix submitted by Jeroen in pull request .
- The application no longer throws a JavaScript error when you delete a product with a custom option of type
file
during creation of an order from the Admin. Fix submitted by adrian-martinez-interactiv4 in pull request .
- Creating a product with no image by using
product_page_image_large
in your layout results in a placeholder image being displayed as expected. Previously, the application threw this error:Fatal error: PHP Fatal error: Uncaught TypeError: Argument 1 passed to Magento\Catalog\Block\Product\ImageFactory::getRatio() must be of the type integer, null given
. Fix submitted by Lukasz Bajsarowicz in pull request .
- You can use the
POST /V1/:sku/links
endpoint to set product links with an empty array of products when the product has existing links. Previously, the application threw an error. Fix submitted by Sathish Subramanian in pull request .
- You can now use the Actions dropdown menu from the Products grid to specify whether a product has weight when you update multiple products鈥檚 attributes from the Admin. Fix submitted by Bartomiej Szubert in pull request .
- Validation logic has been added to the Products per Page on Grid Allowed Values and Products per Page on Grid Default Value fields of the store configuration page. Previously, store administrators could enter unavailable values in these fields. Fix submitted by Lukasz Bajsarowicz in pull request . _
Catalog Rule
- Corrected the behavior of the Datepicker page element on Admin > Marketing > Promotions > Catalog Price Rule. Fix submitted by Hitesh in pull request .
- Catalog price rules now work with custom options as expected on Product details pages. Fix submitted by Pavel Bystritsky in pull request .
Catalog widget
- The
CatalogWidget
products list now works as expected with anchor categories, and products from anchor categories are now matched and displayed. Previously, when you selected a parent category that was an anchor, but that did not contain assigned products, products were not visible in the widget.
- The application now displays all children of a selected parent category as expected. Previously, if you selected a parent category that was an anchor, but that did not contain assigned products, the application did not display all nested products.
- The Recently Viewed Products widget now works correctly when Stores > Configuration > Catalog > Catalog > Recently Viewed/Compared > Synchronize widget products with backend storage is set to Yes.
CMS content
- You can now save and duplicate all CMS pages. Previously, the application threw this exception when you tried to duplicate certain pages:
Unique constraint violation found
.
- The application now lets you create CMS blocks with identical names if the blocks are assigned to different store views.
- Select from Gallery image thumbnails are now cached as expected. Previously, these images were resized on the fly.
- The application no longer throws an error when you save a CMS page that has been assigned to multiple stores. Previously, when you created or edited a CMS page, the application saved the page but also threw this error:
Item (Magento\VersionsCms\Model\Hierarchy\Node) with the same ID "PAGE_ID" already exists
.
- New CMS pages are now added as expected to a website鈥檚 store page hierarchy.
- The CMS page custom layout update logic has been improved. The application now applies specific layout changes from
cms_page_view_selectable_home_somechanges.xml
. Fix submitted by Sergiy Vasiutynskyi in pull request .
Cleanup
- Removed an extra closing tag from module XML. Fix submitted by Tejash Kumbhare in pull request .
- Corrected misalignment of the My billing and shipping address are the same checkbox on the Review and Payments page section of the checkout workflow. Fix submitted by divyajyothi5321 in pull request .
- Removed unnecessary white space between the field labels and asterisks on the Shipping Address section of the checkout workflow. Fix submitted by Daniel Ruf in pull request .
- Corrected misalignment of the radio buttons on the Shipping methods section of the checkout workflow. Fix submitted by Hitesh in pull request .
- Corrected inconsistent menu spacing in mobile view. Fix submitted by Hitesh in pull request .
- Corrected misalignment of the mini cart Edit and Remove icons in mobile view. Fix submitted by Vasilii Burlacu in pull request .
- Corrected misalignment of the tax rate zip/post code range and checkbox on the Add New Tax Rate/Zip Code page (Admin > Store > Taxes > Tax Zones and Rates). Fix submitted by Sathish Subramanian in pull request .
- The link from the Setup Wizard to the Admin now works as expected. Fix submitted by Oleh Usik in pull request .
- Sorting has been disabled on the status column of the Cache Management grid in the Admin. Fix submitted by Sathish Subramanian in pull request .
- Corrected misalignment of page elements on the Admin > Stores > Attributes > Ratings > Add new ratings dialog. Fix submitted by Sathish Subramanian in pull request .
- Corrected misalignment of the calendar icon on the Add Design Change page. Fix submitted by Eduard Chitoraga in pull request .
- Removed unnecessary space in submenu display on the home page hover menu. Fix submitted by Hitesh in pull request .
- Corrected misalignment of the price labels on the storefront product details page. Fix submitted by divyajyothi5321 in pull request .
- Corrected misalignment of the out-of-stock text in relation to the Add to cart button on the product list page in mobile view. Fix submitted by divyajyothi5321 in pull request .
- The integration success message displayed on Admin > System > Extensions > Integrations is now displayed correctly. Fix submitted by divyajyothi5321 in pull request .
Configurable products
- Child products of a configurable product can now be successfully disabled through the API.
- Cart price rules with a condition set as Category (Parent only) now consistently work as expected.
- You can now add a configurable product to the cart from the Cross-Sells tab. When you select a product and click Add to Cart from this tab, you are now taken to the product details page, where you can select specific product options. Previously, the application redirected you to a 404 error page.
- The application no longer links a simple product to a configurable product when the API call to link these products fails.
- Corrected the rendering of SKUs in the Current Variations list for a configurable product. Fix submitted by KaushikChavda in pull request .
- You can now save
system.xml
configuration information by entering values in Admin > System > Configuration in fields that do not have associated labels. Fix submitted by Andrii Chorniy in pull request .
- The performance of
\Magento\ConfigurableProduct\Model\Product\Type\Configurable::isSalable
has been optimized. Fix submitted by Stanislav Ilnytskyi in pull request .
- The logic that is responsible for updating configurable product images has been improved. Previously, simple products associated with a configurable product displayed only the default image associated with the configurable product, and the application sometimes displayed the wrong main image for the product. Fix submitted by Sergiy Vasiutynskyi in pull request . , ,
- The application now displays a product鈥檚 special price as expected when you select a discounted option of a configurable product. Previously,
class="normal-price"
was not changed toclass="special-price"
when a discounted option was selected. Fix submitted by Ravi Chandra in pull request .
Cookies
- The
setRedirectCookie
andclearRedirectCookie
functions now work as expected. Previously, these functions sent cookies to the browser, but all cookie parameters were missing.
- Google Tag Manager tags are no longer triggered when a customer navigates to a new store without accepting the Google Tag Manager cookie.
- Metadata has been added to the
setRedirectCookie
andclearRedirectCookie
functions. Fix submitted by Alexander Lukyanov in pull request .
Custom customer attributes
- The application now displays custom customer address attribute values as expected in the address section of the checkout workflow. Previously, the application displayed the custom customer address attribute code instead of the value, and a JavaScript error was triggered.
- The application no longer throws an error when you include an empty customer attribute field in the Forms to Use In field while creating a Company account on the storefront. Previously, the application threw this error:
PHP Fatal error: Uncaught TypeError: Argument 2 passed to Magento\Eav\Model\Attribute\Data\Text::validateLength() must be of the type string, null given
.
- The application now saves custom customer address attributes and implements them in registration forms as expected. Previously, when you created a new custom customer address attribute while creating an account from the cart, the application did not save the attribute information.
Customer
- Customers who are subscribed to newsletters as a guest are no longer unsubscribed after registering for a new account.
- The application now uses a new
PHPSession
for each change of password.
- You can now successfully create a customer and associate it with a particular website using the Associate to Website dropdown menu on Customers > All Customers > Add new Customer. Previously, when you tried to associate a new customer with the non-default website in a multi-site deployment, the application displayed this error:
The store view is not in the associated website
.
- The application now saves the information a customer enters in the default billing and shipping fields during checkout when the transaction is initially declined due to an invalid credit card but later completed successfully. Previously, although the application created the order when the customer entered valid payment information, it did not update the default billing or shipping addresses in the My Account section of the checkout workflow.
- The application now honors customer group settings when you create a new customer from the Admin in a multi-site deployment.
- The application now successfully imports customer data using the Customer and Addresses (single file) option when
cron
is enabled and the Customer Grid indexer is set to Update By Schedule. Aftercron
executes, the imported customer information is available in the Admin as expected. Previously, the applicationimported the customer data, but did not update the customer grid with the newly imported customer records.
- You can now create a new customer from the storefront when the date of birth is required. Previously, you could not create a new customer when this field was required, even when you entered valid DOB values.
- Customer creation from the Admin now honors the default customer group setting as expected.
- The
PHPSessionId
is now changed as expected after a customer logs out and then logs back in.
- The Admin view of a customer cart now displays all the products that were added to the cart from multiple websites in a multi-website deployment. Previously, when a customer added a product to their cart from a non-default website, the product was not displayed in the Admin even when Share customer account is set to Global.
- Validation now works as expected for the Date of birth field when editing a customer from the Admin. Previously, the application did not factor in the user locale, and for some birthdates displayed this error:
The Date of Birth should not be greater than today
. Fix submitted by Sergiy Vasiutynskyi in pull request .
- The email field is no longer required when placing an order from the Admin. Fix submitted by solwininfotech in pull request .
- The application now displays only the products that the customer has placed in their cart when the cart is viewed from the Admin. Previously, a customer鈥檚 shopping cart displayed all the products in the catalog when viewed from the Admin. Fix submitted by Ravinder in pull request .
- The My Account dashboard now displays the displays email address values correctly in mobile view. Fix submitted by Eden Duong in pull request .
- Clicking the Create an Account button on the customer registration form multiple times no longer submits the registration request more than once. Fix submitted by princeCB in pull request .
Customer segment
- The application no longer removes your customer account from a customer segment when you log in as a user that is assigned to the customer segment when the segment includes a condition for past orders. Previously, you had to click Refresh Segment Data after logging in before the application displayed your account in the Matched Customers list.
- Customer segments now work as expected when segment conditions include the total number of orders.
- Customer segment rules are now applied as expected when customer accounts are set up to be shared globally.
- We鈥檝e improved the performance of editing and saving customer segments that contain large numbers of customers (more than three million). Previously, when you created or edited a customer segment that contained many customers, the application threw a 500 error.
Directory
- The Default State dropdown menu is now populated by data that is based on the allowed countries that have been assigned to the selected website when you configure a value for the Default Tax Destination Calculation field. Previously, this dropdown listed the countries that were assigned to the default website.
Downloadable
- You can now use an import file to update downloadable products in bulk by SKU and description. Previously, validation errors occurred, and import failed.
Dynamic block (formerly banner)
- Dynamic blocks now work with customer segments as expected. The application no longer displays a dynamic block when the condition that should trigger it is not fulfilled. Previously, the application displayed a dynamic block for users logged in as a guest when the shopping cart was empty.
- Dynamic blocks are now rendered on the storefront based on customer segment and store view.
EAV
- The application now respects store-specific settings that determine whether the telephone number field of the checkout workflow is required in a multi-site deployment. Previously, in deployments where one store required this field in the checkout workflow and another store did not, customers who did not complete this field while checking out on the store that did not require it encountered this error:
Please check the shipping address information. "telephone" is required. Enter and try again
.
- EAV sort order by
attribute option_id
now works as expected. Fix submitted by Tan Sezer in pull request .
- You can now create a new product after adding a new attribute via REST and assigning it to an attribute set from the Admin. Previously, the application threw a 500 error. Fix submitted by Sergiy Vasiutynskyi in pull request .
- The authorization emails that are sent to a customer when they request a return now contain the RMA status as expected. Previously, this email displayed an empty string instead of the expected return status.
- Customers are no longer redirected away from the current website when they report a forgotten password in multi-site deployments where customer accounts are shared globally. Previously, customers were redirected to the website on which the account was created.
- Order confirmation emails that are sent to customers now include the list of ordered items as expected. Previously, when you created an email template in the Admin by loading and saving the default template, emails generated from this template did not include the list of ordered items.
Frameworks
- Dependencies on Zend Framework have been migrated to the to reflect the transitioning of Zend Framework to the Linux Foundation鈥檚 Laminas Project. Zend Framework has been deprecated. Fix submitted by Ihor Sviziev in pull request .
- Special price range settings (from/to dates) now work correctly for administrator accounts using a Dutch locale.
-
php bin/magento cron:run
no longer processes items from the change log table multiple times. Previously, when you had more than 100000 new versions in the change log table, actions could be called several times for the sameentity id
. -
The
php bin/magento setup:cron:run
command has now been removed. Also, remove references to this file in crontabs when upgrading. -
The
update/cron.php
file has been removed in 2.4.0, if this file exists on your installation, it can be safely removed. Also, remove references to this file in crontabs when upgrading.
- The Update Attribute action now correctly updates the timestamp of a product鈥檚
updated_at column
fromcatalog_product_entity
when you update the product from the Admin edit product page.
- Setting
'persistent' => '1'
inenv.php
no longer throws an error when you runsetup:upgrade
.
- The Invalid Form Key. Please refresh the page text string on the login page is now translated as expected.
- We鈥檝e improved the performance of the
Magento\Framework\App\DeploymentConfig\Reader::load
function. Previously, when a request was made to Magento, this function was called repetitively, which resulted inconfig.php
andenv.php config
files being loaded each time the method was called.
- The application no longer downloads a
blank.html
page when an administrator clicks on a product while creating an order from the Admin.
- Non-cacheable blocks added to the default layout in reference instructions for non-existent (undeclared) components on the page no longer affect page caching. Adding non-cacheable blocks to default layout handlers renders all pages non-cacheable. This results from the layout generation process: During layout generation, the application collects all available layout handles for a particular page and merges instructions from them into the page鈥檚 final layout structure. The default layout handle is used as a basic handle for every page. As a result, layout updates that are declared for the default handler appear on every page.
- The MySQL lock manager is now the primary lock manager. As a result, the minimal required version of MySQL is 5.7.9.
queue_consumer.xml
now allows numbers in thehandler
class. Previously, when a handler contained a number in its path, XSD validation failed. Fix submitted by Eden Duong in pull request .
- An incorrect
@var
reference in thedoc
block of the class member variable$queueIterator
in class\Magento\Framework\MessageQueue\Topology\Config
has been corrected. Fix submitted by Artem Voloznov in pull request .
- JavaScript page load listeners are now triggered to fire when a document is no longer
loading
rather than waiting until it is marked ascomplete
as waiting until the document is marked ascomplete
can lead to severe delays in rendering JavaScript content. Fix submitted by John Hughes in pull request and pull request .
- The application now displays the following informative message when you try to add a product to your wishlist with a quantity of 0 or negative number:
Please enter a valid number in this field
. Previously, the application displayed this error:We can't update your Wish List right now
. Fix submitted by Pawe Tylek in pull request .
- The application no longer supports inheritance of DTO classes from the
Magento\Framework\Api\AbstractExtensibleObject
class. Missing PHP annotation@api
has been added toAbstractExtensibleModel
, and the missing@deprecated
annotation has been added toAbstractExtensibleObject
. Fix submitted by Alexander Taranovsky in pull request .
- You can now save products as expected after changing a product-related date (for example,
news_from_date
,news_to_date
,special_price_from_date
,special_price_to_date
) in stores implementing non-English locales. Previously, the application threw an error similar to this:Invalid input datetime format of value '22/5/2019
.
General fixes
- The Customer module no longer has a dependency on the Review module. Previously, you could not disable the Review module due to this dependency.
- The product edit page now loads successfully when the default attribute set for the page contains a dropdown attribute with the select label.
- The graphical orders chart accessible from the Orders tab on the Admin now accurately reflects order quantity.
- A store鈥檚 Admin URL no longer redirects to the storefront URL when these two URLs differ.
- URL rewrite generation for subcategories now works correctly when using the performance toolkit profile with more than one website.
- You can now delete an empty user model without deleting the Administrators role to which it is assigned.
- The TinyMCE4 editor now supports all HTML tags.
- Clicking the Refund Offline button in the create a credit memo workflow now generates a credit memo as expected. Previously, a JavaScript error disabled this button, and the application did not create a credit memo.
- Merchants can now create a product attribute of type
Decimal
. Previously, due an earlier bug fix, the application did not display the product attribute typePrice
.
- The application no longer returns a 500 error when you try to open a Category page on the storefront when Layout = Product 鈥 Full Width has been set from the Design tab of the Category page.
- Corrected a bug in
AbstractSimpleObjectBuilder.php
.
- MAP (minimum advertised price) now works as expected for group products.
- The application now redirects you to the home page of the appropriate store view when you change language on CMS pages in a multi-store deployment. Previously, the application displayed a 404 page when you changed language on certain CMS pages.
- Order queries (
SalesOrderIndexGridAsyncInsertCron
) have been refactored to reduce the size of the data set returned and the frequency of the queries.
- You can now successfully create a CMS page and assign it to the website root category in the CMS hierarchy.
- Guests can now display a product price or add a product to the cart when category permissions are enabled (for example, when the Not logged in customer group has been granted these privileges).
- Product rules now apply to out-of-stock products as expected. Previously, the application did not display out-of-stock products in the related products list even when the rule was configured to display out-of-stock products.
- Clicking the Track shipping button for an order from the Admin now results in tracking information being displayed in a pop-up window as expected. Previously, this link took the administrator to the Log in page.
- The application now displays an informative error message and continues to display the registration form as expected if an error occurs when a customer tries to complete a registration form that contains a multi-select customer attribute. Previously, the application displayed a 500 error.
- The application now displays the Credit memo button after the partial refund of an order. Previously, the application did not display this button after you created a partial refund, and you could not create a credit memo for the rest of the order.
- Bulk order updates through REST now modify the order status as expected. Previously, the application threw this error:
report.ERROR: Property "AdditionalInformation" does not have accessor method "setAdditionalInformation" in class "Magento\Sales\Api\Data\OrderPaymentInterface".
- Attribute filters are now displayed as expected in the Shopping Options block of the Category page.
- You can now change the product limit on the Category page from 24 to 36 in deployments where B2B is installed. Previously, the application threw a fatal error when this product limit was increased to 36.
- Customer billing and shipping addresses are now displayed as expected under the Addresses tab on the Admin Customer Edit page when displayed in Internet Explorer. Fix submitted by Vasilii Burlacu in pull request .
- All bookmark views now remain editable when you delete one. Previously, all bookmark views became uneditable after you deleted the first view for accounts with multiple bookmark views. Fix submitted by Bartomiej Szubert in pull request .
- Layered navigation no longer breaks HTML5 validation of the swatch module. Previously, HTML validation errors occurred for attributes that were not defined in the , but those attributes have been changed to data attributes. Fix submitted by Nirav Patel in pull request .
- An unused
require.JS
alias (critical-css-loader``) has been removed from app/code/Magento/Theme/view/frontend/requirejs-config.js
. Fix submitted by Tu Nguyen in pull request .
- The application now implements PHP7.x鈥檚 to enable the catching of all errors that might potentially expose sensitive information such as passwords. Fix submitted by miszyman in pull request .
- Pressing the ESC key when entering the name of a new folder on the create a new folder popup window now closes the popup as expected without creating the folder. Fix submitted by Shankar Konar in pull request .
- An incorrectly nested HTML structure has been corrected. Previously, this structure resulted in a broken layout for the list of related, up-sell, or cross-sell products. Fix submitted by Pieter Hoste in pull request .
- Removed duplicated call to
addToolbarBlock
, which had resulted in two similar conditions inORDER BY
. Fix submitted by Vasilii Burlacu in pull request .
- Merchants can now set an expiration date on Admin user accounts. Fix submitted by Laura Folco in pull request .
- We鈥檝e added the
@api
PHP annotation toAbstractExtensibleModel
, the@deprecated
PHP annotation toAbstractExtensibleObject
, and@see
toAbstractExtensibleModel
. Fix submitted by Alexander Taranovsky in pull request .
Gift cards
- The GET
V1/orders/:orderId
call returns gift card codes as expected.
Gift wrapping
- Gift wrapping can now be added to the cart when it is enabled on the product level. Previously, you could add gift wrapping to a product on the storefront, but the application would not include gift wrapping in the order summary.
- An expired gift card becomes active as expected when you change its expiration date to a future date. Previously, the gift card remained expired.
- The Admin Create Order page now loads correctly when the Allow Gift Messages on Order Level setting and template minification are enabled. Previously, when you tried to open this page when these settings were enabled, the application threw this error:
Warning: require(content.phtml): failed to open stream: No such file or directory
.
- The application now correctly calculates the cost of gift wrapping based on the number of products for which you鈥檝e ordered gift wrap. Previously, the application included the cost of gift wrap for one product only in the order.
Google Tag Manager
- Merchants can now postpone sending data to Google Analytics until specified conditions are met.
- The missing
Magento_GoogleTagManager::checkout/set_checkout_option.phtml
template has been restored.
GraphQL
- The application now returns the GraphQL message
The cart isn't active
instead ofCurrent user does not have an active cart
under certain circumstances when a cart becomes inactive and a new cart ID is created. Fix submitted by Vadim Malesh in pull request .
- Removed code that caused an error when using GraphQL to add products to a cart when a previously added product became out-of-stock. Fix submitted by AleksLi in pull request .
-
Corrected a problem in GraphQL in which the application did not return all the required information while using fragments on products query. Fix submitted by Riccardo Tempesta in pull request .
-
The GraphQL mutation
setShippingMethodsOnCart
no longer retrieves the wrong data in theavailable_shipping_methods
attribute. Fix submitted by Vadim Malesh in pull request .
Grouped products
- You can now add a simple product that belongs to a group product to the shopping cart when another simple product that belongs to that same group is out-of-stock. Fix submitted by Gihovani Filipp Pereira Dem泰trio in pull request .
- The application now sends email to customers about refunded group products as expected. Fix submitted by Alexander Taranovsky in pull request .
- You can now add a child product of a grouped product to your cart when one of the grouped product鈥檚 other child products is out-of-stock. Previously, when one child product was out-of-stock, you could not add any other child products to the cart.
Images
- Images are now saved in
pub/media/catalog/category
as expected when you save category images. Previously, the applicationsaved these images inpub/media/catalog/tmp/category
.
- Watermark images no longer obscure the product image that they overlay. Previously, when the watermark image was larger than the product image it was applied to, the product image was not visible.
- You can now successfully save an image to a category from the Admin. Previously, after you saved the image, part of the URL was missing, and you couldn鈥檛 re-open the image.
- The application now displays
.png
images as expected after upload.
- Images that have been uploaded into a CMS block using Page Builder are now displayed in the preview as expected when uploaded from an Admin that has a base URL that differs from the storefront URL.
- Using REST to add or update an image now creates an image thumbnail as expected. Fix submitted by Sergiy Vasiutynskyi in pull request .
- Custom attributes of images generated by
Block\Product\ImageFactory
now render correctly. Previously, you could not add your own custom attributes to the attribute markup due to incorrect escaping of the HTML output. Fix submitted by alexander-aleman in pull request .
- Images are no longer blurred when a storefront is viewed from an iPhone. Fix submitted by Dmitriy in pull request .
- Images on the storefront are now responsive. Previously, image height was distorted. Fix submitted by Sean van Zuidam in pull request .
- The default store logo is now visible on the storefront when the
Magento_blank
theme is used. Fix submitted by Vasilii Burlacu in pull request .
Import/export
- The application no longer throws an error during import when imported data includes a
swatch_image
store-view key has a value ofno_selection
. Previously, the application threw this error:Imported resource (image) could not be downloaded from external resource due to timeout or access permissions in row(s): 1
.
- The application now updates images as expected when you use the
hide_from_product_page
setting when importing products in deployments with multiple store views.
- Customizable options are now imported as expected when
row_id
is not equal to a product鈥檚entity_id
. Previously, the application did not import customizable options whenrow_id
was not equal to a product鈥檚entity_id
, which resulted in certain products not being imported.
- Images associated with configurable products are now properly uploaded during import and available for viewing as expected from the product edit page.
- Exported
.csv
files now reflect filter settings for including in-stock or out-of-stock products. Previously, the applicationexported all products, no matter which stock setting you selected.
- You can now successfully import or update customers using the Customer and addresses single file option of the import workflow. Previously, when you selected this option, the application did not import the customer data and displayed this error:
Invalid data for insert
.
- The Stock Indexer is now triggered as expected after import and updates product status. Previously, the Stock Indexer did not index the changed product inventory data.
- The application now successfully imports all custom options for a configurable product鈥檚 child products when
store_view_code
is specified. This works whether you choose to import configurable products individually or collectively. Previously, the application did not successfully import all custom options when the import file contained more than one item andstore_view_code
was specified.
- The application now provides a message during product import that identifies which products in the imported
.csv
file have duplicated keys. Merchants can use this information to resolve conflicts. Previously, the application displayed this error:Notice: Undefined index: name in /var/www/html/ee233dev/app/code/Magento/CatalogImportExport/Model/Import/Product.php on line 2524
- The application now displays a more informative error message, and does not display a download link, when you try to delete a directory from the System > Export list. Previously, when you tried to delete a directory from this list, the application continued to display a download link for files that could not be downloaded, and displayed an uninformative error message.
- The
.csv
file that is used during import now contains the correct links for downloadable products and is now correctly formatted to support importing and updating downloadable products.
- The application now successfully exports a
.csv
file when you set import behavior for Replace, select a previously exported.csv
file, and click Check data. Previously, the application displayed this error:Data validation failed. Please fix the following errors and upload the file again
andFollowing Error(s) has been occurred during importing process
.
- The Stock Indexer is now triggered as expected after import and updates product status. Previously, the Stock Indexer did not index the changed product inventory data.
.csv
files that are generated during product import now contain group titles for downloadable products as expected. Previously, unnecessary validation ofgroup_title
during import prevented the display of group titles for downloadable products.
- When
cron
is enabled and you perform a customer import using the (Customer and Addresses (single file)) option, the application populates data to the Admin customer grid as expected. The customer grid displays the customers once manual re-indexing completes forcustomer_grid indexer
. Previously, the application did not update the customer grid with newly imported customer addresses.
- The application now displays the customer list as expected after automatic re-indexing. Previously, although manually running
bin/magento index:reindex
worked, the customer grid did not display customer information after automatic re-indexing.
- The application now deletes temporary files from
<Magento_home>/var
as expected after product import has completed.
- The application no longer creates duplicate SKUs in the Admin when products are imported by
.csv
file.
- Import no longer fails when the imported configurable attribute includes an equal sign (=) in its value. Fix submitted by dhoang89 in pull request .
- All exported grid data (both 51黑料不打烊 Commerce and custom data) now have option labels instead of option values for all the columns with type
Select
orMultiselect
. Previously, when you exported this data, the exported spreadsheet contained Columns with ID rather than the values that were displayed in the grid. Fix submitted by Maksym Novik in pull request .
- The application now displays bundle products on the storefront as expected after you update a product by importing a
.csv
file. Fix submitted by Pavel Bystritsky in pull request .
Index
- We have improved the performance of
indexer_update_all_views
. Indexing is now faster, inactive rules are no longer processed, and caches are cleared of entries for only changed products.
- Product prices on the storefront now accurately reflect the application of a scheduled Catalog Price Rule update. Previously, prices did not reflect the scheduled cart price rule until you manually re-indexed (
php bin/magento indexer:reindex catalogrule_rule
).
- You can now successfully re-index the product database after adding an attribute that is unsearchable (that is, the
is_searchable
,is_filterable
,is_visible_in_advanced_search
attributes are disabled).
- The application now displays a message that identifies the indexer and the time the indexing operation took when a re-indexing operation fails. Fix submitted by Lukasz Bajsarowicz in pull request .
- Products that are saved in stores where the
onthefly
indexer and flat tables are enabled now respect website assignments. Previously, if you removed all website assignments from a product and then saved it, all flat tables included the product, despite the specified website assignments. Fix submitted by Abel Truong in pull request .
Infrastructure
- The Internet Explorer 11.x browser is no longer supported.
- The validation logic that is associated with the Date of Birth field of the Customer Registration form no longer triggers a JavaScript error.
- Added an integration test to cover
$storeId
for the Category Repositoryget()
method. Fix submitted by Lukasz Bajsarowicz in pull request .
- Enabling the Block all cookies setting in Safari no longer results in JavaScript errors, and the application displays the
cookies disabled
message as expected. Previously, the application displayed multipleSecurityError (DOM Exception 18): The operation is insecure
errors in the console. Fix submitted by Ra碳l Verdugo Lorenzo in pull request .
- The application no longer throws this error when running integration tests:
Error: Call to a member function findFile() on array (/var/www/html/lib/internal/Magento/Framework/Code/Generator/DefinedClasses.php:59)
. Previously, an issue withAutoloaderRegistry::getAutoloader
caused integration tests to fail randomly. Fix submitted by Lukasz Bajsarowicz in pull request .
- The
date
tag in/module-sales/view/frontend/templates/order/order_date.phtml
has been corrected tospan
. Previously, the application logged an error in theexception.log
file when you clicked View Order on the storefront My Account > My Orders page. Fix submitted by Andrii Chorniy in pull request . ,
- The JavaScript mixin module has been refactored to improve the loading and application of mixins for advanced bundled modules. Previously, the application did not load or apply mixins for advanced bundled modules. Fix submitted by Mateusz Krzeszowiak in pull request .
- The
grunt clean
command now cleans generated code and metadata folders as expected. Fix submitted by Andrii Beziazychnyi in pull request .
getVersion
result (ProductMetadata::getVersion
) is now cached, which improves performance of theProductMetadata::getVersion
method. Fix submitted by Lukasz Lewandowski in pull request .
- A missing setter for
additional_information
has been added toOrderPaymentInterface
, which resolves an inconsistency between its schema declaration and accepted properties. Fix submitted by Antonino Bonumore in pull request . ,
Layered navigation
- The application now renders the Yes/No attribute on the Category page when Use in Layered Navigation: Filterable (with results) for storefront properties is enabled.
- Redundant
\Magento\Sales\Model\Order\Email\Sender\ShipmentSender
has been deprecated in favor of\Magento\Sales\Model\Order\Shipment\Sender\EmailSender
. Fix submitted by Adarsh Manickam in pull request .
Logging
- Order status changes are now logged as expected under System > Action Logs > Report.
- The application now logs sales shipment actions in the Admin Action log as expected.
- CMS page save actions are now logged in Admin Action Logs. Previously, only view actions were logged.
- Save actions on CMS pages are now logged as expected in Admin action logs when Select all actions to be logged is enabled on the Admin Actions Logging tab (Admin > Stores > Configuration > Advanced).
- CMS page modifications are now logged as expected in the Action log. MFTF now covers this feature. Fix submitted by Lukasz Bajsarowicz in pull request .
Media Gallery
- Clicking Enter after naming a new folder in the Media Gallery now saves all changes you鈥檝e made. Previously, clicking Enter instead of using the mouse to select OK resulted in all changes being lost. Fix submitted by Sergiy Vasiutynskyi in pull request .
- You can now create a subfolder under the Media Gallery that has the same name as the primary folder. Previously, you could not save the subfolder with the same name. Fix submitted by Vadim Malesh in pull request .
Media Storage
var/resource_config.json
is no longer regenerated whenever an image is requested byget.php
. Previously, this file was rewritten on each call toget.php
.
New Relic
- 51黑料不打烊 Commerce
cron
job names are now included as expected within Transaction Traces in the NewRelic APM Monitoring - Transactions. This includescron
jobs that are executed from the command line as well as jobs executed by the standard scheduler. Fix submitted by Lukasz Bajsarowicz in pull request .
Newsletter
- Customers can now subscribe as expected to newsletters. Previously, when a customer tried to confirm their subscription, the application displayed this error:
This is an invalid subscription confirmation code
.
- The newsletter input field of the storefront footer is now rendered identically by any supported browser. Fix submitted by divyajyothi5321 in pull request .
- Storefront messages about newsletter subscriptions are now rendered as expected in HTML. Fix submitted by Oleh Usik in pull request .
Orders
- Order summary subtotals no longer display excluded taxes when the website display settings specify that taxes should be excluded. Previously, when multiple websites were configured with different display settings, the setting defined in the server variable was used for the store despite the store-level configurations.
Payment methods
- The integration of third-party payment methods Authorize.Net, eWay, CyberSource, Braintree, and Worldpay into the core code have been removed. Merchants should migrate to the official extensions that are available on the Commerce Marketplace.
- The core implementation of Signifyd fraud protection is no longer supported. Merchants should migrate to the that is available on Commerce Marketplace.
- You can now successfully complete an order and return to the merchant鈥檚 home page when Website Payments Pro Hosted Solution is configured. Previously, when you clicked Return to merchant, the application threw this error:
Invalid Form Key. Please refresh the page
.
- Switching billing address no longer causes JavaScript function text to render in the payment section of the storefront checkout workflow. Fix submitted by Chris Pook in pull request .
- Credit memos now display the correct amount in the Adjustment Refund field of the Credit Memo overview. Fix submitted by Sergiy Vasiutynskyi in pull request .
- You can now remove additional information from the
quote_payment column additional_information
table after you鈥檝e saved a quote. Previously, you could not remove this information after saving the quote because theunsAdditionalInformation
method in\Magento\Payment\Model\Info
did not initialize data properly. Fix submitted by Marco Oliveira in pull request .
- Payment instructions are now derived from the store view from which an order was made. Previously, payment instructions were used from the default store view because the
BeforeOrderPaymentSaveObserver
method fetched payment instructions from the default store view. Fix submitted by Karyna Tsymbal in pull request .
- The application now collects the payment information that is displayed on both the Admin and in invoice and shipment invoices from the store in which the order was made in deployments with multiple stores. Previously, the applicationderived payment information from the default store. Fix submitted by Bartomiej Szubert in pull request .
PayPal
- The application now displays an informative error message each time a customer clicks Pay with PayPal after entering an invalid shipping address in the checkout workflow. Previously, the application displayed an error message only when the customer first clicked the button, not for subsequent clicks.
- The application no longer changes an order鈥檚 status to
Processing
in the Payment Review section of the checkout workflow when a payment with PayPal fails.
- You can now successfully complete an order using the Payflow Link payment method. Previously, the Payflow Link payment method always rejected payment because the order status remained in the
Pending
payment state, even though the order status in the payment method logs wasApproved
.
- Orders that are placed using PayPal Payflow Pro are now set to
Suspected Fraud
status when fraud filters are triggered.
- You can now use PayPal Express Checkout with any supported credit card. Previously, when you clicked on a credit card button while using PayPal Express Checkout to complete an order, the application hung, and you could not enter any credit card information.
- Orders placed within PayPal Payflow Pro are now set to
Suspected Fraud
status when fraud filters are triggered. Previously, payment transaction status on PayPal was not validated before payment approval occurred on the the application side.
- Payflow Pro now works as expected when Website Restrictions are enabled.
- The application now successfully processes orders placed with PayPal Express Checkout where the order鈥檚 shipping address specifies a country region that the customer has manually entered into the text field rather than selected from the drop-down menu on the Shipping page. Previously, the application displayed this error on the order review page:
Error 500: NOTICE: PHP message: PHP Fatal error: Uncaught Error: Call to a member function getId() on null in httpdocs/vendor/magento/module-paypal/Model/Api/Nvp.php:1527
.
- The PayPal Pro payment method now works as expected in the Chrome 80 browser. This payment method previously invoked a callback endpoint that needed access to the customer鈥檚 session 鈥 access that the new default Chrome SameSite cookie functionality does not permit.
- You can now successfully use PayPal Express to pay for an order when persistent checkout cart has been enabled and the Clear Persistence on Sign Out setting is set to no. Previously, the application redirected you to the Login page.
- Payments from Paypal Express and Web Payments Pro now move to the
Processing
state as expected once processing has begun. Previously, Paypal Web Payments Pro payments remained in thePending
payment state even when payment information was in theProcessing
state. Fix submitted by azambon in pull request .
Performance
- Customer data section invalidation logic has been improved. This release introduces a new way of invalidating all customer sections data that avoids a known issue with local storage when custom
sections.xml
invalidations are active. (Previously, private content (local storage) was not correctly populated when you had a custom etc/frontend/sections.xml with action invalidations.) See .
- The import of customer accounts has been refactored to improve import speed.
- Merchants can now use to load images. Fix submitted by Timon de Groot in pull request .
- Dashboard charts have been migrated to the
chart.js
library. Fix submitted by Bartomiej Szubert in pull request .
- The performance of operations that are run on large catalogs that contain many product attributes (on the scale of 3,000 - 23000 options) has been improved by the refactoring of the how attribute option arrays are built. Fix submitted by Behnam Shayani in pull request .
Pricing
- The application now saves and displays the correct price for tiered products even after you鈥檝e edited products multiple times. Previously, the application did not save the last edits made to product price. Fix submitted by Ravi Chandra in pull request .
- Both fixed and discount save percentage are now correctly applied on an order鈥檚 final price. Previously, the application displayed an incorrect tier price (both fixed & discount) save percentage on the product detail page. Fix submitted by Sathish Subramanian in pull request .
Product alert
- The stock alert email sent to customers about the re-stocking of a configurable product now contains the correct product price. Previously, this email contained a product price of 0.
- Product stock alert unsubscribe now works when a user鈥檚 session has expired. Previously, when you clicked on the Click here to stop alerts for this product link, the application displayed a 404 error.
- Unsubscribe actions for product alerts now work as expected. Previously, when a customer clicked on the Click here to stop alerts for this product link, the application displayed a 404 error.
Product video
- You can now use REST to update YouTube videos (PUT
rest/V1/products/{SKU}
). Previously, the application displayed a thumbnail for the video, but the video player did not load when you clicked the Play button.
Reports
- Product lists now order configurable products by SKU, which groups configurable products by variations. Previously, the report grouped products by
product_id
. Fix submitted by Lukasz Bajsarowicz in pull request .
- The Admin > Reports > Refresh Statistics table now displays Updated At = Null status as Never in the Updated column instead of undefined. Fix submitted by Eden Duong in pull request .
- The Low Stock report no longer includes disabled products. Fix submitted by Mohamed-Asar in pull request .
- The application now displays an accurate value for the Year-To-Date Starts field in Admin > Stores > Configuration > General > Reports. Fix submitted by Priya-V-Panchal in pull request .
Return Merchandise Authorizations (RMA)
- The application no longer displays an error when you successfully create an order and RMA from the storefront. Previously, the application created the RMA as expected, but also displayed this error:
We can't create a return right now. Please try again later
.
- Tracking links included in storefront order returns now work as expected. Previously, when a customer clicked the shipment tracking link on the order return page, the application displayed this error:
PHP Fatal error: Uncaught Error: Call to a member function getTitle() on null in /app/z7kvt3uys6daq/var/view_preprocessed/pub/static/vendor/magento/module-shipping/view/frontend/templates/tracking/details.phtml:1
.
- The Returns tab is now present as expected after you create an order return from the Admin.
- An unnecessary string has been removed from the RMA email template (
app/code/Magento/Rma/view/frontend/email/new.html
).
Reviews
- The application now disables the Submit Review button after the user clicks the button once. Previously, the application did not disable this button after the first click and created multiple reviews when the user clicked the Submit Review button multiple times.
- The Admin > Reports > Reviews > By Products filter list now displays results as expected. Previously, when you tried to filter this list, the application did not display any results.
- The Pending Reviews menu item is now activated as expected on Admin > Marketing > User Content > Pending Reviews. Fix submitted by Ravinder in pull request .
Rewards
- The application now refunds reward points as expected when an order is returned to a store running in a multi-store environment where different reward point rates are set for each store. Previously, the application did not refund points as expected for a returned order that was purchased using reward points.
Sales
- Completed orders now appear in both the payment system and 51黑料不打烊 Commerce. Previously, orders appeared in the payment system but not in 51黑料不打烊 Commerce.
- The application now honors a customer鈥檚 default shipping address. Previously, the application did not honor the default billing and default shipping addresses according to the settings, and the Same As Billing Address setting was not enabled automatically.
- The application now correctly calculates refunds for orders that include discounts. Previously, the applicationincorrectly calculated the shipping tax and shipping discount, and the refunded total did not match the total paid.
- The application now assigns the correct Group ID when a new customer creates an order in multi-site deployments. Previously, the application applied the settings from the default customer group.
- Administrators with restricted permissions that include view permission for credit memos, invoices, and shipments can now view invoices and shipments from the Orders page as expected. Previously, when a restricted administrator tried to view an order, the application displayed this error:
Something went wrong with processing the default view and we have restored the filter to its original state
.
- The application no longer displays an error when a customer adds a quantity of a product to their cart that exceeds half of the existing product stock but does not exceed the total stock. Previously, under these circumstances, the application displayed this error:
The requested qty is not available
.
- You can now successfully add a product to the cart from the Admin when the stock quantity is 1. Previously, the application didn鈥檛 add the product to the cart and displayed this message:
The requested qty is not available
. Fix submitted by Serhii Petrychenko in pull request .
- The application now displays an informative error message when a store administrator tries to re-order a product whose custom option has a name that exceeds the maximum number of characters. Previously, under these conditions, the application displayed the Report page, not a message. Fix submitted by Mudit Shukla in pull request .
- The layout of the Sales order address information edit form has been refactored to match Admin form library conventions. Fix submitted by Alexey Rakitin in pull request .
- The checkboxes on the Products section of the Catalog > Categories page now work as expected. Fix submitted by Denis Kopylov in pull request .
- The
getCustomer
method now returns the customer object as defined inphpdoc
block. Previously, this method returnedNULL
, andphpdoc
block did not highlight that this method could returnNULL
. Fix submitted by Fanis Strezos in pull request .
- Re-orders are now disabled as expected when a merchant disables the Admin > Store > Configuration > Sales > Reorder > Allow Order. Fix submitted by Eden Duong in pull request .
getPrice()
method now returns a float or null instead of a string when setting a custom price for an order in the Admin. Fix submitted by Andrii Chorniy in pull request .
- The State Code and Title column of Admin > Stores > Settings > Order Status now displays state instead of status as expected. Fix submitted by Oleh Usik in pull request .
- PDF invoices now capture the correct purchase date when created in a GB locale. Fix submitted by Eden Duong in pull request .
Sales Rule
quote_item.applied_rule_ids
is now updated as expected after a cart price rule is disabled.
- The application now displays category trees as expected when you try to create or edit a cart price rule. Previously, selecting a category in the Condition section while creating or editing a rule resulted in JavaScript errors.
- The application now correctly calculates cart-level fixed discounts using cart price rules when a configurable product is first added to the cart. Fix submitted by Lachlan Turner in pull request .
Search search-heading
- Elasticsearch 7.6.x is now the default catalog search engine for 51黑料不打烊 Commerce and 51黑料不打烊 Commerce. You cannot install or upgrade to version 2.4.0 without also installing Elasticsearch 7.6.x. Elasticsearch version 2.x code has been removed. Elasticsearch versions 5.x and 6.x have been deprecated and are no longer supported. See Search engine prerequisites.
- The application now renders the < and > symbols correctly in storefront catalog search strings.
- Products now show as expected in categories after running
cron:run
in deployments implementing Elasticsearch.
- The application no longer requires a full search re-index in order for a new product attribute to be searchable on the storefront.
- Elasticsearch now works as expected when you sort a product list that contains bundle products by alphabetized product names.
- Filtering results no longer include out-of-stock options when you filter configurable products in a category.
- Selecting all products from the products list page using Elasticsearch now displays all products in the search results as expected. Previously, the application displayed no search results.
- Elasticsearch now correctly displays results from category pages when you change the number of search results viewed per page. Previously, when you changed how many search results should be displayed on the search results page, the application displayed a blank page and this error:
"0":"SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near'
- Price sorting now works correctly for out-of-stock configurable products.
- The application no longer throws an exception when a customer uses the storefront quick search in multi-website deployments.
- The application no longer displays a warning when a merchant opens the search term page by clicking on the Search terms option on the footer of Marketing > SEO & Search > Search Terms. Fix submitted by vishal-webkul in pull request .
- The application no longer resizes the viewport when you click on the search input box when running Safari in mobile view. Fix submitted by Pawe Tylek in pull request .
- The Elasticsearch versions are now identified by X.x notation instead of X.0+ notation in the Admin (Stores > Settings > Configuration > Catalog > Catalog > Catalog Search). Fix submitted by Andreas Mautz in pull request .
Shipping
- You can now ship an order to multiple addresses if one of the ordered products is a virtual product. Previously, the applicationsuccessfully placed the order for the physical products, but the virtual product order was empty.
- The application now applies fixed-amount, whole-cart discounts correctly for orders being shipped to multiple addresses. Previously, this type of discount was applied multiple times when a customer checked out an order using Check Out with Multiple Addresses.
- The drop-down list that is available for selecting shipping methods during the process of creating a cart price rule now contains only valid values. Previously, this dropdown list contained empty or extra values.
- The application now prints shipping labels as a
.pdf
file as expected when you select Print Shipping Label from the Action drop-down list from an order in the order archive list. Previously, the application displayed a 404 error.
- Free Shipping Price rules now affect only the relevant products when a shopping cart contains products from categories that are included by the Free Shipping Price rule as well as products from categories not included in the rule. Previously, when a shopping cart included products from both the free shipping categories as well as other categories not included in the price rule, then free shipping was not applied to any products.
-
The application no longer displays a blank page instead of displaying all the shipping carriers in the dropdown/multi-select box. Previously, an error in the
toOptionArray
function invendor/magento/module-shipping/Model/Config/Source/Allmethods.php
occurred. Fix submitted by Marc Rodriguez in pull request . -
The application no longer applies a fixed amount discount multiple times when a customer creates an order that will be shipped to multiple addresses. Fix submitted by Mahesh Singh in pull request .
- Plugins for
Magento\Ups\Model\Carrier
that implement customdi.xml
now work properly in developer mode. Previously, the application threw this error:1 exception(s): Exception #0 (BadMethodCallException): Missing required argument $data of Magento\Ups\Model\Carrier
. Fix submitted by Bartomiej Szubert in pull request .
Sitemap
- The application now uses the project base URL as expected when you generate a sitemap.
- Generated site maps now include the URL of the home page. Fix submitted by deepaksnair in pull request .
Staging
- Administrators with restricted access to one website only in a multi-site deployment can now preview a Scheduled Update for that website. Previously, the staging preview used the default store by default, and if the user did not have access to the default store, the application threw an exception.
- Editing an existing schedule no longer results in a duplicated schedule. Previously, when you edited an existing schedule, the application duplicated it, and when you tried to open the duplicate schedule, the application threw an error.
- Cross-sell products are now displayed as expected on View and Edit Cart pages after creating a Schedule Update for one or more of these products.
Store
- Customer sessions now persist as expected when a customer logs in to one store, adds products to the shopping cart, and then switches to a new store in a multi-store deployment. Previously, when the customer navigated to the second store, the application logged out the customer and emptied the shopping cart.
- The application now deletes records that are related to a deleted store view from the
sale_sequence_meta
andsales_sequence_profile
tables as expected. Fix submitted by Bartomiej Szubert in pull request .
- Store switcher now works as expected when switching between stores that have different base URLs. Previously, when a customer used the store switcher to switch between stores, the request failed if the target store had a different base URL than the current store. Fix submitted by Tobias Nilsson in pull request . ,
Swatches
- Merchants can now successfully add color swatch attributes to products using the Visual Swatch option on Stores > Attributes > Product > New Attribute. Previously, a JavaScript error was triggered when you tried to open the newly created swatch attribute.
- The Minimum Advertised Price now changes as expected when a customer selects a new swatch option for a configurable product. Fix submitted by Sergiy Vasiutynskyi in pull request .
- The application no longer duplicates the Minimum Advertised Price for a configurable product when you select a new swatch option. Fix submitted by Sergiy Vasiutynskyi in pull request .
- Corrected issues with the behavior of the drop-down menu in the Manage Swatch (Values of Your Attribute) area of the New Product Attribute page. Fix submitted by Oleh Usik in pull request .
TargetRule
- The related product block that is displayed for a product on the storefront now displays the products that have met the criteria defined in the Related Product Rule. Previously, the application did not display any related products.
Tax
- The application now updates shipping rates and prices as expected when a customer changes the destination country for an order during checkout.
- Free shipping is now applied as expected based on the applicable cart price rule. Previously, cart price rules did not take into account taxes when calculating whether an order meets criteria for free shipping.
- The application no longer throws an error when you edit and save the
NOT LOGGED IN
customer group when B2B is installed.
Test
- Hardcoded URLs in tests and Action roups have been replaced with page references. Fix submitted by Lukasz Bajsarowicz in pull request 117 in private repository partners-magento2ee.
- Tests now cover the task of logging Admin Actions related to CMS pages. Fix submitted by Lukasz Bajsarowicz in pull request 172 in private repository partners-magento2ee.
- Invalid functional test names have been revised to follow best practices. Fix submitted by Lukasz Bajsarowicz in pull request and pull request 151 in private repository partners-magento2ee.
- 51黑料不打烊 Commerce
cron
is now used for re-indexing after creating test data, and where applicable,cache:flush config
replacescache:flush
. Fix submitted by Lukasz Bajsarowicz in pull request .
- Acceptance tests now follow naming conventions for
Magento/Indexer
andMagento/Backup
modules. Fix submitted by Shankar Konar in pull request .
- The
AdminReorderWithCatalogPrice
test has been refactored and no longer fails during the CI validation process. Fix submitted by Lukasz Bajsarowicz in pull request 135 in private repository partners-magento2ee.
- The
AdminAddingNewOptionsWithImagesAndPricesToConfigurableProduct
andStorefrontApplyPromoCodeDuringCheckout
tests have been refactored and no longer fail during CI validation process. Fix submitted by Lukasz Bajsarowicz in pull request and pull request . ,
- The
DeleteProduct and DeleteCustomer Action Groups
tests have been refactored and no longer fail during the CI validation process. Fix submitted by Lukasz Bajsarowicz in pull request .
- The
AdminMoveAnchoredCategoryTest.xml
tests have been refactored and no longer fail during the CI validation process. Fix submitted by Lukasz Bajsarowicz in pull request .
Integration tests
- Consecutive requests in integration tests no longer fail. Previously, tests failed because request objects were shared between dispatches. The
resetRequest
method now empties the state ofrequest
. Fix submitted by Lukasz Bajsarowicz in pull request .
- Additional integration tests added to cover for
Magento_Customer
email features. Fix submitted by Lukasz Bajsarowicz in pull request .
PHP unit tests
- PHP unit tests no longer throw this fatal error:
Fatal error: Class Mock_CartExtensionInterface_0ba80a0b contains 2 abstract methods and must therefore be declared abstract or implement the remaining methods (Magento\Quote\Api\Data\CartExtensionInterface::getAmazonOrderReferenceId, Magento\Quote\Api\Data\CartExtensionInterface::setAmazonOrderReferenceId) in /var/www/html/vendor/phpunit/phpunit-mock-objects/src/Generator.php(264) : eval()'d code on line 1
. Fix submitted by Lukasz Bajsarowicz in pull requests 178 in private repository partners-magento2ee and .
- Tests for
Offline_Payments
are now compatible with PHPUnit 8. Fix submitted by Cristiano Pacheco in pull request .
- Unit tests for
Framework
,AdminAnalytics
,AdminNotification
, andAMPQ
have been updated for PHPUnit 8. Fix submitted by Ihor Sviziev in pull requests , , , .
- You can now run the
\Magento\Downloadable\Test\Unit\Helper\DownloadTest
unit test without being connected to the internet. Fix submitted by aleromano89 in pull request .
- Added unit test for
app/code/Magento/Fedex/Model/Source/Generic.php
. Fix submitted by Sathish Subramanian in pull request .
<magentoCron>
has been added to multiple tests, which triggers partial reindexing. This changes addresses issues that created false negatives in functional tests that coveredMagento_Bundle
,CatalogImportExport
,CatalogInventory
,CatalogRule
,Backend
,Braintree
, andCaptcha
. Fix submitted by Lukasz Bajsarowicz in pull requests , , .
- All incorrect uses of
<amOnPage>
have been replaced with an appropriate<actionGroup>
for Admin log out where applicable in tests. Fix submitted by Lukasz Bajsarowicz in pull request 116 in private repository partners-magento2ee.
-
Each Action group in a test has been moved to a separate file to follow MFTF best practices, and inconsistent file names have been revised. Tests for the following modules have been affected:
- module-catalog-permissions
- module-shared-catalog
- module-catalog-event
- module-banner
- module-admin-gws
- module-advanced-checkout
- module-shipping
- module-ui
- module-shipping
- module-checkout-address-search
- module-sales
- module-catalog
- module-catalog-rule-staging
- module-visual-merchandiser
- module-customer
Fix submitted by Lukasz Bajsarowicz in pull requests , , , , , , , (and pull requests 104, 105, 106, 107, 108, 109, 111, 119, 120, 121 in private repository partners-magento2ee).
Theme
- We鈥檝e resolved a bug in
JsFooterPlugin.php
that affected the display of dynamic blocks. Previously, the application displayed this error when you directly accessed/banner/ajax/load/url
:Uncaught TypeError: strpos() expects parameter 1 to be string, null given in
.
- The
i18n
method provides the ability to add a string to underscore templates. Fix submitted by Sergiy Vasiutynskyi in pull request .
- The
section-config
module has been refactored. This refactoring has reduced errors that were caused by third-party modules making POST requests or requesting customer data directly before the module was initialized bydata-mage-init
. Fix submitted by Mateusz Krzeszowiak in pull request .
LoadCssAsync
HTML format errors have been fixed. Fix submitted by Sathish Subramanian in pull request .
- When you create
default.xml
andcatalog_product_view.xml
files as part of creating a new theme, the application either creates these pages or logs errors in the log files as expected. Previously, the application logged errors invendor/magento/framework/View/Page/Config/Renderer.php
file. Fix submitted by Vinh Le in pull request .
Translation and locales
- Inline translation now works as expected on the storefront when Admin > Stores > Configuration > Advanced > Developer > Translate Inline > Enabled for Storefront is set.
- Inline translation now works as expected when enabled for a storefront.
- Product URL keys are now transliterated as expected. Fix submitted by DanieliMi in pull request .
- The
es_US Spanish (United States)
locale is now supported. Fix submitted by Vinh Le in pull request .
- Numerical placeholder count and JavaScript code placeholder count are now the same. Previously, the JavaScript code assumed 0% while the numerical placeholder count started with %1. Fix submitted by korostii in pull request .
- You can now disable the translation of the page title of the Product details page (
page.main.title
), which is enabled by default. Fix submitted by Bartomiej Szubert in pull request .
- Issues with the rendering of Arabic and Hebrew in invoice PDFs have been resolved. Fix submitted by Ihor Sviziev in pull request .
- Language pack inheritance order is now applied in a first-listed, first-used basis as expected and as described in the documentation. Fix submitted by Sergiy Vasiutynskyi in pull request .
- The application now displays this error message when you enter a non-Latin character for a folder name in locales where only Latin letters are supported:
Please rename the folder using only Latin letters, numbers, underscores and dashes
. Fix submitted by Eden Duong in pull request .
- The length of the
locale
column fordirectory_country_region_name
has been increased from 8 to 16 to support locales such aszh_Hans_CN
. Fix submitted by Bartomiej Szubert in pull request .
UI
- You can now use Page Builder to add a product as a button link (Edit Content > Button Link). Previously, the application threw this error when you tried to select the product:
Product with ID: XXXX doesn't exist
.
- The Back button now works as expected from Admin > Stores > Order Status > Edit Order Status. Fix submitted by Vadim Malesh in pull request .
- Preview images no longer change unexpectedly when you use the arrow keys to move the cursor in the File Name field in the 51黑料不打烊 Stock list. Fix submitted by Adarsh Manickam in pull request .
- The Your Password field on the Current User Identity Verification section of the Admin > System > Integrations page now inherits styles as expected. Fix submitted by Eduard Chitoraga in pull request .
- Input that is validated by the JavaScript validator on the storefront will also pass validation on the Admin. Previously, the JavScript validator counted newlines as a single character on the storefront, but on the server side,
\Magento\Catalog\Model\Product\Option\Type\maxCharacters
counted newlines as two characters. Fix submitted by Grzegorz Bogusz in pull request .
- The
subTitle
tag is no longer erased when you change a modal title using thesetTitle()
call. Previously, when you tried to create a popup or custom modal with a title and subtitle, then changed title with thesetTitle()
method, thesubTitle
was erased. Fix submitted by Andrea Parmeggiani in pull request .
- The submenu in the Admin Marketing tab now automatically adjusts to the length of menu items as expected. You can also now scroll horizontally. Fix submitted by Pawe艂 Tylek in pull request .
- The table
quote
columncustomer_note
now uses typetext
as expected. Previously, it used typevarchar(255)
. Fix submitted by Ravi Chandra in pull request .
- Corrected display issues with the table header on the My Account > Address Book Address Entries table. Fix submitted by Abrar Pathan in pull request .
- The currency symbol used in Layered Navigation Price Step is now based on default settings as expected. Fix submitted by Bartomiej Szubert in pull request .
- The symbol for the Belarusian currency (BYR) has been updated to BYN. Fix submitted by Bartomiej Szubert in pull request .
- The Compare Products section of the Catalog page is now displayed as expected in mobile view on displays with resolutions of less than 767px. Fix submitted by Hitesh in pull request .
- Scrolling of product pages now works as expected in mobile view. Fix submitted by Mateusz Krzeszowiak in pull request . ,
- You can now scroll through gallery thumbnail images on the product page in mobile view as expected. Fix submitted by iGerchak in pull request .
- Clicking on Theme Title on Admin > Content > Themes no longer results in duplicate records. Fix submitted by Eden Duong in pull request .
- The layout of the Admin Billing Address/Shipping Address page has been refactored to meet Admin form display conventions. Fix submitted by Alexey Rakitin in pull request . ,
- The Add to Compare link on the product detail page now renders correctly in mobile view on displays with less than 640px resolution. Fix submitted by Pawe Tylek in pull request and Tejash Kumbhare in pull request .
- The Sort By label no longer overlaps with the Shop By button on the category page in mobile view. Fix submitted by Andrii Kartavtsev in pull request .
- You can now update the value of a downloadable product鈥檚 sample and link title by enabling the Use default checkbox. Fix submitted by Abel Truong in pull request .
- Corrected spacing between the Update button and Qty field on the mini cart. Fix submitted by Hitesh in pull request .
- The bottom border color of the Additional Address Entries table on the Address Book page now matches
thead
andtbody
border color. Fix submitted by Tejash Kumbhare in pull request .
- Prompt modals no longer carry out a confirm action when a user clicks on the modal overlay. Fix submitted by Serhiy Zhovnir in pull request .
URL
- The category repository (save method) has been refactored, which had previously prevented you from creating unique paths when changing a category URL key. Fix submitted by Sergiy Vasiutynskyi in pull request .
- Validation for the category URL key logic has been improved. Fix submitted by Sergiy Vasiutynskyi in pull request .
URL rewrites
- Customers who change language on a CMS page can now successfully navigate to the store view they鈥檝e selected. Previously, the application displayed a 404 error.
- URL rewrite generation for product URLs for which you鈥檝e enabled category path inclusion now works as expected. Previously, in deployments with multiple store views, the application sometimes generated incorrect URL rewrites by using the default value of the category url path instead of the storeview-specific URL path. Fix submitted by Pieter Hoste in pull request . ,
- We鈥檝e added a check to prevent URL redirects if the request path is the same as the target path. Fix submitted by Bartomiej Szubert in pull request .
- URL rewrite operations no longer removes a query string from a URL when the URL has a trailing slash. Fix submitted by Alexey Arendarenko in pull request .
VAT
- Corrected the VAT Validation URL for . Fix submitted by Shikha Mishra in pull request .
Visual Merchandiser
- The edit category page now behaves as expected when you drag and drop products to a new position. Previously, dragging and dropping products on any category page repositioned the viewing window at the top of the page.
Web API framework
- Corrected issues with the POST
/rest/default/async/bulk/V1/orders
calls.
- Corrected issues with the POST
/rest/default/async/bulk/V1/products
calls.
- The
getList
method has been refactored to retrieve theis_subscribed
extension attribute. Previously, you could not retrieve this attribute when fetching a customer entity through the API. Fix submitted by enriquei4 in pull request .
- Updating customer information through
/V1/customers/:id
no longer resets thegroup_id
unnecessarily. Previously, when you updated a customer through REST, the customer group was changed to 1 if the body did not contain a customer group. Fix submitted by MaxRomanov4669 in pull request .
- Nullable getters in service contracts no longer throw reflection errors when used in the web API. Methods that can return null and a valid type now working correctly regardless of order, too. Fix submitted by Marco K苔pcke in pull request .
- You can now use POST
/V1/guest-carts/:cartId/items
to add products to a specific cart. Previously, when you used this call, the application ignored the value ofcartId
. Fix submitted by Vadim Malesh in pull request .
- You can now use the
PUT /V1/cmsPage/:id
endpoint to save a CMS page title without changing the values of other fields. Fix submitted by Vadim Malesh in pull request .
- The pagination of results from REST requests is now accurate. Previously, when you requested results from a specific page (for example,
page_size
= 1 and acurrent_page
value that was out of scope), the call returned repeated the last page of results rather than an informative message . Fix submitted by Lukasz Bajsarowicz in pull request . ,
- The result of GET
/V1/orders/items/{id}
now includes an extension attribute element that includes gift message data. Fix submitted by Laura Folco in pull request .
Wishlist
- A wishlist now works as expected when it is enabled at the store-view level and disabled at the global level. Previously, when these settings were in place, adding a product to a wishlist resulted in a 404 error.
- The application now correctly saves and displays a new name for a wishlist when you rename a wishlist in deployments that contain multiple wishlists. Previously, the applicationcontinued to display the former wishlist name.
- You can now navigate and modify wishlists from the cart in deployments running Internet Explorer 11.x. Previously, you could not create, edit, or move a wishlist in this environment.
- We鈥檝e improved the error message that is displayed when a customer tries to share their wishlist with more email addresses than is permitted. Fix submitted by divyajyothi5321 in pull request .
- The application now displays the My Wishlist page as expected in displays with resolution greater than 768px and less than 1023px. Fix submitted by Hitesh in pull request .
- The email generated when you click Share Wishlist now displays the same product images as the Wishlist page. Fix submitted by Michael Bottens in pull request .
- Customers can now add to a wishlist both a simple product that is part of grouped product and the same simple product with a different quantity. Fix submitted by MaxRomanov4669 in pull request .
WYSIWYG
- The WYSIWYG image uploader now uses
pub/media/wysiwyg
as the storage root. Previously, the uploaded usedpub/media
as its storage root, which made those uploaded images inaccessible after recent changes to image uploader code. Fix submitted by Pieter Hoste in pull request .
- TinyMCE4 on the Chrome browser now handles double-byte characters as expected. Previously, TinyMCE4 could not properly handle double-byte characters (such as used in Chinese) on Chrome. Fix submitted by Hirokazu Nishi in pull request .
Known issues 鈥 general
Issue: Anomalies in storefront error messages occur in deployments where PHP 7.4.2 is installed. When 2.4.0 is deployed with PHP 7.4.2, the space symbols in storefront error messages are replaced with plus (+) characters. This bug is native to PHP 7.4.2 and cannot be corrected by 51黑料不打烊 Commerce. Workaround: We recommend using other versions of PHP 7.4.x. See Knowledge Base article.
Issue: Merchants cannot add ordered products to a package from the Admin Create Package page and save the package. See Knowledge Base article. The MC-35514-2.4.0-CE-composer.patch hotfix for this issue is now available from .
Issue: The application displays this error message during installation with third-party extensions that have dependencies on APIs for the Store
module in CLI commands: The default website isn't defined. Set the website and try again
. Workaround: Remove dependencies on third-party extensions from Composer, install Magento, and then install third-party extensions.
Issue: The Add selections to my cart button on the bottom of the shopping cart does not work. Workaround: Use the Add selections to my cart button on the top of the page. See Knowledge Base article.
Issue: Merchants cannot interact with any page elements on the Returns page after creating a shipping label for a Return Merchandise Authorization (RMA). See Knowledge Base article. The MC-35984-2.4.0-composer.patch hotfix for this issue is now available from .
Issue: Administrators cannot add a configurable product by SKU to a quote. When an administrator clicks on the Add to Quote button, the Quote Edit page remained in a loading state, and the administrator could not save their changes. Workaround: There is no workaround for B2B Quote editing. However, you can still order products by selecting the products from the products list instead of adding them by SKU. See Knowledge Base article.
Issue: Merchants can鈥檛 create a new order from the Admin because the Add Products By SKU and Add Products buttons are missing from the order creation page when JavaScript bundling is enabled. Workaround: Disable the JavaScript bundling for your deployment.
Issue: The application a 404 not found
error when a customer tries to remove reward points when checking out an order being shipped to multiple addresses.
Issue: Editing a configurable product from a customer鈥檚 wishlist results in the following unexpected behavior: An unexpected field appears on the Configure Product page, and the Configure Product page does not disappear after you click OK. The application also displays this message: Please load Wish List item
. Workaround: Reload the Configure Product page.
Issue: Customers cannot change the number of orders displayed per page when the Orders list spans multiple pages. Currently, the application displays this message when you navigate to the last page of orders and try to change the number of orders displayed per page: You have placed no orders
. See Knowledge Base article. Workaround: Re-opening the My Orders page will result in the display of the Orders list.
Issue: Directly clicking on the Export Tax Rates button of the Add New Tax Rule page ( Stores > Tax Rules) does not download the tax_rates.csv
file as expected. Workaround: Click the edge of the Export Tax Rates button. See Knowledge Base article.
Issue: The Refresh buttons on the Last Ordered Items, Products in Comparison List, and Recently Compared Products sections of the Admin Customer Activities page do not work as expected. Currently, the application scrolls the page every time the Refresh button is clicked and does not display the product name. See Knowledge Base article.
B2B
Issue: If a discount code expires before a Purchase Order (PO) is approved, the PO continues to display the discounted amount, but once the PO is approved, the order is placed at the non-discounted total. Workaround: Install the B2B-709 Purchase Order Discount patch hotfix for this issue, which is now available from the My Account > Downloads section of magento.com
.
Issue: The application an exception during upgrade to B2B 1.2.0 in a multi-website deployment. When setup:upgrade
runs, this error occurs on the PurchaseOrder
module: Module Magento_PurchaseOrder: Unable to apply data patch Magento\PurchaseOrder\Setup\Patch\Data\InitPurchaseOrderSalesSequence for moduleMagento_PurchaseOrder
. Workaround: Install the B2B-716 Add NonTransactionableInterface interface to the InitPurchaseOrderSalesSequence data patch hotfix, which is now available from the My Account > Downloads section of magento.com
.
Known issues 鈥 VBE
Amazon Pay
-
Issue: Payment methods are missing from the checkout workflow when a customer clicks Return to standard checkout during checkout with Amazon Pay. Workaround: Refresh the checkout page to display the missing methods.
-
Issue: The application displays two identical Amazon Pay methods in the Payment Method drop-down list that is available when creating a new cart price rule.
Braintree
-
Issue: The application displays an error when an administrator tries to access the Braintree Settlement Report page (Admin > Reports ). Currently, the application displays this message:
An error has happened during application run. See exception log for details
. See Knowledge Base article. The BUNDLE-2683_SettlementReport.patch hotfix for this issue is now available from . -
Issue: Merchants can鈥檛 create partial invoices for orders in deployments where Venmo is enabled and the Enable Vault for Card Payments setting is disabled. Currently, the application displays this error:
The "vault_capture" command doesn't exist. Verify the command and try again
. -
Issue: The application displays two identical PayPal methods in the Payment Method drop-down list that is available when creating a new cart price rule.
-
Issue: The application an error when opening Sales > Braintree Virtual Terminal. Although the form contains corrupted UI elements, it still accepts payments. Workaround: Save the correct Braintree credentials, which will fix the collapsed input fields. See Knowledge Base article. The BUNDLE-2670_VirtualTerminal.patch hotfix for this issue is now available from .
-
Issue: The application displays an error message in the following countries when a customer selects a local payment method during checkout: Belgium, Netherlands, Italy, Spain, and Poland. Workaround: Ignore the error message and continue with payment.
dotdigital
- Issue: Integration tests fail with this error:
PHP Fatal error: Declaration of Dotdigitalgroup\Email\Test\Integration\Model\Sync\Importer\ImporterFailedTest::setUp() must be compatible with PHPUnit\Framework\TestCase::setUp(): void in /var/www/vendor/dotmailer/dotmailer-magento2-extension/Test/Integration/Model/Sync/Importer/ImporterFailedTest.php on line 36
. Workaround: The BUNDLE-2684 Dotdigital Integration Tests patch hotfix for this issue is now available from .
Klarna
- Issue: Leaving the Design Theme field blank in Klarna On-Site Messaging (Admin > Stores > Configuration > Klarna settings) results in a blank page. Workaround: Select a design theme and save.
Vertex
- Issue: the application displays an Address verification button on the shipping section of the checkout workflow even when address validation is disabled. The address validator doesn鈥檛 re-check the updated address and continues to display a message that indicates that the address is invalid when a customer enters a correct address after first entering an incorrect address even when address validation is enabled. Workaround: Disable Vertex address validation.
Community contributions
We are grateful to the wider Magento Open Source community and would like to acknowledge their contributions to this release. Check out the following ways you can learn about the community contributions to our current releases:
-
If a community member has provided a fix for this release, we identify the fix in the Fixed Issue section of these notes with the phrase, 鈥Fix provided by community member鈥.
-
The Community Engineering team maintains a list of top contributing individuals and partners by month, quarter, and year. From that Contributors page, you can follow links to their merged PRs on GitHub.
Partner contributions
The following table highlights contributions made by Partners. This table lists the Partner who contributed the pull request, the external pull request, and the GitHub issue number associated with it (if available).
Individual contributor contributions
The following table identifies contributions from our community members. This table lists the external pull requests, the GitHub issue number associated with it (if available), and the community member who contributed the pull request.
System requirements
Our technology stack is built on PHP and MySQL. For more information, see System Requirements.
Installation and upgrade instructions
You can install 51黑料不打烊 Commerce 2.4.0 using Composer.
Migration tool kits
The Data Migration Tool helps transfer existing Magento 1.x store data to Magento 2.x. This command-line interface includes verification, progress tracking, logging, and testing functions. For installation instructions, see Install the Data Migration Tool. Consider exploring or contributing to the .
The helps transfer existing Magento 1.x store extensions and customizations to Magento 2.x. The command-line interface includes scripts for converting Magento 1.x modules and layouts.