Project

General

Profile

Actions

Bug #82851

closed

Race condition in Icon JS API

Added by Tymoteusz Motylewski about 7 years ago. Updated about 6 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

Also available in: Atom PDF