From f080de53808061c2cd754960eb210c2f60d6e154 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Felix=20Geisend=C3=B6rfer?= Date: Sun, 6 Dec 2009 18:57:20 +0100 Subject: [PATCH] Two bug fixes for process.mixin Bug #1 occurred when trying to use process.mixin on a function and produced a fatal exception. Bug #2 occurred when trying to do a deep merge with an object containing one or more objects with a nodeType property. In those cases the deep copy for this part of the object was not performed and a shallow one was performed instead. Both of these bugs were artifacts of the jQuery.extend port. --- src/node.js | 4 ++-- test/mjsunit/test-process-mixin.js | 16 ++++++++++++++++ 2 files changed, 18 insertions(+), 2 deletions(-) create mode 100644 test/mjsunit/test-process-mixin.js diff --git a/src/node.js b/src/node.js index 2a52c251c80..1e091d02898 100644 --- a/src/node.js +++ b/src/node.js @@ -109,7 +109,7 @@ process.mixin = function() { } // Handle case when target is a string or something (possible in deep copy) - if ( typeof target !== "object" && !process.isFunction(target) ) + if ( typeof target !== "object" && !(typeof target === 'function') ) target = {}; // mixin process itself if only one argument is passed @@ -130,7 +130,7 @@ process.mixin = function() { continue; // Recurse if we're merging object values - if ( deep && copy && typeof copy === "object" && !copy.nodeType ) + if ( deep && copy && typeof copy === "object" ) target[ name ] = process.mixin( deep, // Never move original objects, clone them src || ( copy.length != null ? [ ] : { } ) diff --git a/test/mjsunit/test-process-mixin.js b/test/mjsunit/test-process-mixin.js new file mode 100644 index 00000000000..840079a35d5 --- /dev/null +++ b/test/mjsunit/test-process-mixin.js @@ -0,0 +1,16 @@ +process.mixin(require("./common")); + +var target = function() {}; +process.mixin(target, { + foo: 'bar' +}); + +assert.equal('bar', target.foo); + +// This test verifies there are no DOM-related aspects to process.mixin which +// originally had been in there due to its jQuery origin. +var fakeDomElement = {deep: {nodeType: 4}}; +target = {}; +process.mixin(true, target, fakeDomElement); + +assert.notStrictEqual(target.deep, fakeDomElement.deep); \ No newline at end of file