Assign methods should create an object when object is nullish.

This commit is contained in:
John-David Dalton
2016-01-07 21:53:35 -08:00
parent 6fa9490a13
commit 8bd8aa3037
2 changed files with 15 additions and 10 deletions

View File

@@ -3835,7 +3835,7 @@
function createAssigner(assigner) {
return rest(function(object, sources) {
var index = -1,
length = object == null ? 0 : sources.length,
length = sources.length,
customizer = length > 1 ? sources[length - 1] : undefined,
guard = length > 2 ? sources[2] : undefined;

View File

@@ -6015,17 +6015,22 @@
}
});
QUnit.test('`_.' + methodName + '` should not error when `object` is nullish and sources are provided', function(assert) {
assert.expect(1);
QUnit.test('`_.' + methodName + '` should create an object when `object` is nullish', function(assert) {
assert.expect(2);
var expected = lodashStable.times(2, alwaysTrue);
var source = { 'a': 1 },
values = [null, undefined],
expected = lodashStable.map(values, alwaysTrue);
var actual = lodashStable.map([null, undefined], function(value) {
try {
return lodashStable.isEqual(func(value, { 'a': 1 }), {});
} catch (e) {
return false;
}
var actual = lodashStable.map(values, function(value) {
var object = func(value, source);
return object !== source && lodashStable.isEqual(object, source);
});
assert.deepEqual(actual, expected);
actual = lodashStable.map(values, function(value) {
return lodashStable.isEqual(func(value), {});
});
assert.deepEqual(actual, expected);