Tuesday, 5 October 2021

UNHANDLEDREJECTION Callback was already called in aysnc parallel

I am using async parallel to get data from db in parallel. When every task is returning the data I am storing it in local object.

From index.js I am calling cacheService.js . In cacheService.js I am loading data from mysql database and mongo database in to cache object. Whenever I am doing npm run local run. I am getting following error.

UNHANDLEDREJECTION Error: Callback was already called.

This error is coming from loadMongoData method of cacheService.js. I have followed other answers on stackoverflow like adding else part

Here is code for cacheService.js.

'use strict';

var cache = [];
class cacheService {
    async init() {
        await this.loadMongoData();
    }

  
loadMongoData(env, callback1) {
    const _this = this;
    console.log('Inside loadMongoData')
    async.parallel(
        {
            task1: function (callback) {
                CriteriaDef.find({})
                    .lean()
                    .exec(function (err, criteriaDefs) {
                        if (err) {
                            console.log('Inside err 1')
                            logger.error('Error fetching CriteriaDef: ', util.inspect(err));
                            callback(err, null);
                        } else if (criteriaDefs) {
                            console.log('Inside criteriaDefs')
                            if (criteriaDefs.length && criteriaDefs.length > 0) {
                                console.log('Inside criteriaDefs 1')
                                global.CRITERIA_DEFS = criteriaDefs;
                                cache['criteria_defs'] = criteriaDefs;
                            }
                            callback(null, null);
                        }
                    });
            },
            task2: function (callback) {
                groupDef
                    .find({})
                    .lean()
                    .exec(function (err, groupDefs) {
                        if (err) {
                            console.log('Inside err2')
                            logger.error('Error fetching groupDefs: ', util.inspect(err));
                            callback(null, err);
                        } else if (groupDefs) {
                            console.log('Inside ')
                            global.groupDefsWithRoles = groupDefs;
                            let _groupDefs = [];
                            _.each(groupDefs, function (groupDef) {
                                var data = {
                                    value: groupDef._id,
                                    label: `${groupDef._id}: ${groupDef.description}`
                                };
                                _groupDefs.push(data);
                            });
                            global.groupDefs = _groupDefs;
                            cache['groupDefs'] = _groupDefs;
                            logger.info('Loaded groupDefs: ', global.groupDefs.length);
                            callback(null, null);
                        }
                    });
            },
            task3: function (callback) {
                jiraProjects.find({$or: [{archived: {$ne: true}}, {archived: {$exists: false}}]}).exec(function (err, jiraProjects) {
                    if (err) {
                        console.log('Inside error 3')
                        logger.error('Error fetching jiraProjects: ', err);
                        callback(null, err);
                    } else if (jiraProjects) {
                        console.log('Inside jira project')
                        let _jiraProjects = [];
                        _.each(jiraProjects, function (jiraProject) {
                            var data = {
                                value: jiraProject.key,
                                label: jiraProject.key,
                                issueType: jiraProject.issueType ? jiraProject.issueType : 'Bug'
                            };
                            _jiraProjects.push(data);
                        });
                        global.jiraProjectsList = _jiraProjects;
                        cache['jiraProjects'] = _jiraProjects;
                        logger.info('Loaded jira projects: ', global.jiraProjectsList.length);
                        callback(null, null);
                    }
                });
            },
            task4: function (callback) {
                console.log('Inside task4')
                callback(null, null);
            },
            task5: function (callback) {
                inputElements
                    .find({})
                    .lean()
                    .exec(function (err, inputElements) {
                        if (err) {
                            console.log('Inside error5')
                            logger.error('Error fetching inputElements: ', util.inspect(err));
                            callback(null, err);
                        } else if (inputElements) {
                            console.log('Inside inputelements')
                            global.INPUT_ELEMENTS_DEF = inputElements;
                            cache['INPUT_ELEMENTS_DEF'] = inputElements;
                            callback(null, null);
                        }
                    });
            },

            task6: function (callback) {
                console.log('Inside task6')
                sisp.loadProducts('', callback);
            }
        },
        function (err, results) {
            if (err) {
                console.log('Inside final error')
                logger.error("Something went wrong can't start the app: ", util.inspect(err));
                callback1(null, err);
            } else {
                console.log('Inside final else')
                logger.info('loaded all globals properly :)');
                callback1(null, null);
            }
        }
    )
}
}
export default new cacheService();


from UNHANDLEDREJECTION Callback was already called in aysnc parallel

No comments:

Post a Comment