mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-01-31 15:27:50 +00:00
* test: fix throttle.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix pickBy.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix isBuffer.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: partially fix attempt.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: partially fix dropRightWhile.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix defer.spec.js and rest.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix invoke.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix isArray.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: partially fix iteration-methods.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix xor-methods.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix property.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix ary.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix omit-methods.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix debounce-and-throttle.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix unzip-and-zip.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix toPairs-methods.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix exit-early.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: temporarily comment out takeWhile and dropWhile tests Signed-off-by: tison <wander4096@gmail.com> * test: partially fix union*.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix startsWith-and-endsWith.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix isNil.spec.js Signed-off-by: tison <wander4096@gmail.com> * test: fix some of syntax errors Signed-off-by: tison <wander4096@gmail.com> --------- Signed-off-by: tison <wander4096@gmail.com>
88 lines
2.5 KiB
JavaScript
88 lines
2.5 KiB
JavaScript
import lodashStable from 'lodash';
|
|
import { noop, stubA, stubB, stubOne } from './utils';
|
|
import invoke from '../src/invoke';
|
|
|
|
describe('invoke', () => {
|
|
it('should invoke a method on `object`', () => {
|
|
const object = { a: lodashStable.constant('A') };
|
|
const actual = invoke(object, 'a');
|
|
|
|
expect(actual).toBe('A');
|
|
});
|
|
|
|
it('should support invoking with arguments', () => {
|
|
const object = {
|
|
a: function (a, b) {
|
|
return [a, b];
|
|
},
|
|
};
|
|
const actual = invoke(object, 'a', [1, 2]);
|
|
|
|
expect(actual).toEqual([1, 2]);
|
|
});
|
|
|
|
it('should not error on nullish elements', () => {
|
|
const values = [null, undefined];
|
|
const expected = lodashStable.map(values, noop);
|
|
|
|
const actual = lodashStable.map(values, (value) => {
|
|
try {
|
|
return invoke(value, 'a.b', [1, 2]);
|
|
} catch (e) {}
|
|
});
|
|
|
|
expect(actual).toEqual(expected);
|
|
});
|
|
|
|
it('should preserve the sign of `0`', () => {
|
|
const object = { '-0': stubA, 0: stubB };
|
|
const props = [-0, Object(-0), 0, Object(0)];
|
|
|
|
const actual = lodashStable.map(props, (key) => invoke(object, key));
|
|
|
|
expect(actual).toEqual(['a', 'a', 'b', 'b']);
|
|
});
|
|
|
|
it('should support deep paths', () => {
|
|
const object = {
|
|
a: {
|
|
b: function (a, b) {
|
|
return [a, b];
|
|
},
|
|
},
|
|
};
|
|
|
|
lodashStable.each(['a.b', ['a', 'b']], (path) => {
|
|
const actual = invoke(object, path, [1, 2]);
|
|
expect(actual).toEqual([1, 2]);
|
|
});
|
|
});
|
|
|
|
it('should invoke deep property methods with the correct `this` binding', () => {
|
|
const object = {
|
|
a: {
|
|
b: function () {
|
|
return this.c;
|
|
},
|
|
c: 1,
|
|
},
|
|
};
|
|
|
|
lodashStable.each(['a.b', ['a', 'b']], (path) => {
|
|
expect(invoke(object, path)).toEqual(1);
|
|
});
|
|
});
|
|
|
|
// FIXME: Work out a solution for _.
|
|
//
|
|
// it('should return an unwrapped value when implicitly chaining', () => {
|
|
// const object = { a: stubOne };
|
|
// expect(_(object).invoke('a')).toBe(1);
|
|
// });
|
|
//
|
|
// it('should return a wrapped value when explicitly chaining', () => {
|
|
// const object = { a: stubOne };
|
|
// expect(_(object).chain().invoke('a') instanceof _)
|
|
// });
|
|
});
|