Skip to content

Commit 0b9c503

Browse files
authored
Deferred: Respect source maps in jQuery.Deferred.exceptionHook
So far, `jQuery.Deferred.exceptionHook` used to log error message and stack separately. However, that breaks browser applying source maps against the stack trace - most browsers require logging an error instance. This change makes us do exactly that. One drawback of the change is that in IE 11 previously stack was printed directly and now just the error summary; to get to the actual stack trace, three clicks are required. This seems to be a low price to pay for having source maps work in all the other browsers, though. Safari with the new change requires one click to get to the stack trace which sounds manageable. Fixes gh-3179 Closes gh-5192 Ref https://crbug.com/622227
1 parent 6d13644 commit 0b9c503

File tree

2 files changed

+5
-5
lines changed

2 files changed

+5
-5
lines changed

src/deferred/exceptionHook.js

+2-2
Original file line numberDiff line numberDiff line change
@@ -10,8 +10,8 @@ jQuery.Deferred.exceptionHook = function( error, stack ) {
1010

1111
if ( error && rerrorNames.test( error.name ) ) {
1212
window.console.warn(
13-
"jQuery.Deferred exception: " + error.message,
14-
error.stack,
13+
"jQuery.Deferred exception",
14+
error,
1515
stack
1616
);
1717
}

test/unit/deferred.js

+3-3
Original file line numberDiff line numberDiff line change
@@ -575,9 +575,9 @@ QUnit.test( "jQuery.Deferred.exceptionHook", function( assert ) {
575575
defer = jQuery.Deferred(),
576576
oldWarn = window.console.warn;
577577

578-
window.console.warn = function() {
579-
var msg = Array.prototype.join.call( arguments, " " );
580-
assert.ok( /barf/.test( msg ), "Message: " + msg );
578+
window.console.warn = function( _intro, error ) {
579+
assert.ok( /barf/.test( error.message + "\n" + error.stack ),
580+
"Error mentions the method: " + error.message + "\n" + error.stack );
581581
};
582582

583583
jQuery.when(

0 commit comments

Comments
 (0)