Project

General

Profile

Actions

Bug #82851

closed

Race condition in Icon JS API

Added by Tymoteusz Motylewski over 6 years ago. Updated over 5 years ago.

Status:
Closed
Priority:
Should have
Category:
-
Target version:
-
Start date:
2017-10-24
Due date:
% Done:

100%

Estimated time:
TYPO3 Version:
8
PHP Version:
Tags:
Complexity:
Is Regression:
Sprint Focus:

Description

When you require the same icon multiple times through Icon API in the same moment, API will make multiple calls to PHP backend, because it's stores the cache only after the first request is back.

It should be changed in the way, that instead of caching the value, we cache the promise object.

How to test it:
Just run following js code in the browser console e.g. in the page module.

require(['TYPO3/CMS/Backend/Icons'], function(Icons) {
   ['mimetypes-x-sys_category', 'mimetypes-x-sys_category', 'mimetypes-x-sys_category', 'mimetypes-x-sys_category','mimetypes-x-sys_category'].forEach(function(item,index){
   Icons.getIcon(item, Icons.sizes.small, null, null, 'inline').done(function(icon) {
      console.log(icon);
   });
   });
});

You will see multiple requests being made for getting the same icon.

Actions #1

Updated by Gerrit Code Review over 6 years ago

  • Status changed from Accepted to Under Review

Patch set 2 for branch master of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/54470

Actions #3

Updated by Gerrit Code Review over 6 years ago

Patch set 1 for branch TYPO3_8-7 of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/54486

Actions #4

Updated by Tymoteusz Motylewski over 6 years ago

  • Status changed from Under Review to Resolved
  • % Done changed from 0 to 100
Actions #5

Updated by Benni Mack over 5 years ago

  • Status changed from Resolved to Closed
Actions

Also available in: Atom PDF