FreeMarker12
FreeMarker12

Reputation: 115

* Suitescript 2.0 * How can update the status of a custom record from Map Reduce script?

So all i want to do is if the m/r script fails, update the corresponding dropdown value on custom record from m/r script.

How to do this in SuiteScript 2.0

Upvotes: 0

Views: 1896

Answers (1)

Adolfo Garza
Adolfo Garza

Reputation: 3029

You can use the summary step to get the errors that occurred in your Map Reduce script. The following code should help you achieve this:

function summarize(summary) {
    handleErrors(summary);
    handleSummaryOutput(summary.output);

    //*********** HELPER FUNCTIONS ***********

    function handleErrors(summary) {
        var errorsArray = getErrorsArray(summary);
        if(!errorsArray || !errorsArray.length){
            log.debug('No errors encountered');
            return;
        }

        for (var i in errorsArray) {
            log.error('Error ' + i, errorsArray[i]);
        }

        if(errorsArray && errorsArray.length){
            //
            //INSERT YOUR CODE HERE
            //
        }

        return errorsArray;

        //*********** HELPER FUNCTIONS ***********
        function getErrorsArray(summary){
            var errorsArray = [];

            if (summary.inputSummary.error){
                log.audit('Input Error', summary.inputSummary.error);
                errorsArray.push('Input Error | MSG: ' + summary.inputSummary.error);
            }

            summary.mapSummary.errors.iterator().each(function (key, e){
                var errorString = getErrorString(e);
                log.audit('Map Error', 'KEY: ' + key + ' | ERROR: ' + errorString);
                errorsArray.push('Map Error | KEY: ' + key + ' | ERROR: ' + errorString);
                return true; //Must return true to keep looping
            });

            summary.reduceSummary.errors.iterator().each(function (key, e){
                var errorString = getErrorString(e);
                log.audit('Reduce Error', 'KEY: ' + key + ' | MSG: ' + errorString);
                errorsArray.push('Reduce Error | KEY: ' + key + ' | MSG: ' + errorString);
                return true; //Must return true to keep looping
            });

            return errorsArray;

            //*********** HELPER FUNCTIONS ***********
            function getErrorString(e){
                var errorString = '';
                var errorObj = JSON.parse(e);
                if (errorObj.type == 'error.SuiteScriptError' || errorObj.type == 'error.UserEventError'){
                    errorString = errorObj.name + ': ' + errorObj.message;
                } else {
                    errorString = e;
                }
                return errorString;
            }
        }
    }

    function handleSummaryOutput(output){
        var contents = '';
        output.iterator().each(function (key, value){
            contents += (key + ' ' + value + '\n');
            return true;
        });
        if(contents){
            log.debug('output', contents);
        }
    }
}

Upvotes: 1

Related Questions