mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-01-31 15:27:50 +00:00
Avoid unnecessary cloning in fp set methods. [closes #2017]
This commit is contained in:
@@ -691,7 +691,7 @@
|
||||
actual = fp.unset('a.b')(value);
|
||||
|
||||
assert.deepEqual(value, deepObject, 'fp.unset');
|
||||
assert.deepEqual(actual, { 'a': { 'c': 3 } }, 'fp.set');
|
||||
assert.deepEqual(actual, { 'a': { 'c': 3 } }, 'fp.unset');
|
||||
});
|
||||
}());
|
||||
|
||||
@@ -731,6 +731,42 @@
|
||||
|
||||
/*--------------------------------------------------------------------------*/
|
||||
|
||||
QUnit.module('set methods');
|
||||
|
||||
(function() {
|
||||
var array = [1, 2, 3],
|
||||
object = { 'a': 1 },
|
||||
deepObject = { 'a': { 'b': 2, 'c': 3 } };
|
||||
|
||||
QUnit.test('should only clone objects in `path`', function(assert) {
|
||||
assert.expect(8);
|
||||
|
||||
var object = { 'a': { 'b': { 'c': 1 }, 'd': { 'e': 1 } } },
|
||||
value = _.cloneDeep(object),
|
||||
actual = fp.set('a.b.c.d.e', 3, value);
|
||||
|
||||
assert.ok(_.isObject(actual.a.b.c), 'fp.set');
|
||||
assert.ok(_.isNumber(actual.a.b.c), 'fp.set');
|
||||
|
||||
assert.strictEqual(actual.a.b.c.d.e, 3, 'fp.set');
|
||||
assert.strictEqual(actual.d, value.d, 'fp.set');
|
||||
|
||||
value = _.cloneDeep(object);
|
||||
actual = fp.setWith(Object)('a.b.c')(2)(value);
|
||||
|
||||
assert.strictEqual(actual.a.b.c, 2, 'fp.setWith');
|
||||
assert.strictEqual(actual.d, value.d, 'fp.setWith');
|
||||
|
||||
value = _.cloneDeep(object);
|
||||
actual = fp.unset('a.b')(value);
|
||||
|
||||
assert.notOk('b' in actual, 'fp.unset');
|
||||
assert.strictEqual(actual.d, value.d, 'fp.unset');
|
||||
});
|
||||
}());
|
||||
|
||||
/*--------------------------------------------------------------------------*/
|
||||
|
||||
QUnit.module('with methods');
|
||||
|
||||
(function() {
|
||||
|
||||
Reference in New Issue
Block a user