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>
146 lines
4.5 KiB
JavaScript
146 lines
4.5 KiB
JavaScript
import lodashStable from 'lodash';
|
|
import { stubOne, _, stubTwo, stubThree, stubFour, noop, slice } from './utils';
|
|
import constant from '../src/constant';
|
|
|
|
describe('methodOf', () => {
|
|
it('should create a function that calls a method of a given key', () => {
|
|
const object = { a: stubOne };
|
|
|
|
lodashStable.each(['a', ['a']], (path) => {
|
|
const methodOf = _.methodOf(object);
|
|
expect(methodOf.length).toBe(1);
|
|
expect(methodOf(path)).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('should work with deep property values', () => {
|
|
const object = { a: { b: stubTwo } };
|
|
|
|
lodashStable.each(['a.b', ['a', 'b']], (path) => {
|
|
const methodOf = _.methodOf(object);
|
|
expect(methodOf(path)).toBe(2);
|
|
});
|
|
});
|
|
|
|
it('should work with a non-string `path`', () => {
|
|
const array = lodashStable.times(3, constant);
|
|
|
|
lodashStable.each([1, [1]], (path) => {
|
|
const methodOf = _.methodOf(array);
|
|
expect(methodOf(path)).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('should coerce `path` to a string', () => {
|
|
function fn() {}
|
|
fn.toString = lodashStable.constant('fn');
|
|
|
|
const expected = [1, 2, 3, 4];
|
|
const object = {
|
|
null: stubOne,
|
|
undefined: stubTwo,
|
|
fn: stubThree,
|
|
'[object Object]': stubFour,
|
|
};
|
|
const paths = [null, undefined, fn, {}];
|
|
|
|
lodashStable.times(2, (index) => {
|
|
const actual = lodashStable.map(paths, (path) => {
|
|
const methodOf = _.methodOf(object);
|
|
return methodOf(index ? [path] : path);
|
|
});
|
|
|
|
expect(actual).toEqual(expected);
|
|
});
|
|
});
|
|
|
|
it('should work with inherited property values', () => {
|
|
function Foo() {}
|
|
Foo.prototype.a = stubOne;
|
|
|
|
lodashStable.each(['a', ['a']], (path) => {
|
|
const methodOf = _.methodOf(new Foo());
|
|
expect(methodOf(path)).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('should use a key over a path', () => {
|
|
const object = { 'a.b': stubOne, a: { b: stubTwo } };
|
|
|
|
lodashStable.each(['a.b', ['a.b']], (path) => {
|
|
const methodOf = _.methodOf(object);
|
|
expect(methodOf(path)).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('should return `undefined` when `object` is nullish', () => {
|
|
const values = [, null, undefined];
|
|
const expected = lodashStable.map(values, noop);
|
|
|
|
lodashStable.each(['constructor', ['constructor']], (path) => {
|
|
const actual = lodashStable.map(values, (value, index) => {
|
|
const methodOf = index ? _.methodOf() : _.methodOf(value);
|
|
return methodOf(path);
|
|
});
|
|
|
|
expect(actual).toEqual(expected);
|
|
});
|
|
});
|
|
|
|
it('should return `undefined` for deep paths when `object` is nullish', () => {
|
|
const values = [, null, undefined];
|
|
const expected = lodashStable.map(values, noop);
|
|
|
|
lodashStable.each(
|
|
['constructor.prototype.valueOf', ['constructor', 'prototype', 'valueOf']],
|
|
(path) => {
|
|
const actual = lodashStable.map(values, (value, index) => {
|
|
const methodOf = index ? _.methodOf() : _.methodOf(value);
|
|
return methodOf(path);
|
|
});
|
|
|
|
expect(actual).toEqual(expected);
|
|
},
|
|
);
|
|
});
|
|
|
|
it('should return `undefined` if parts of `path` are missing', () => {
|
|
const object = {};
|
|
const methodOf = _.methodOf(object);
|
|
|
|
lodashStable.each(['a', 'a[1].b.c', ['a'], ['a', '1', 'b', 'c']], (path) => {
|
|
expect(methodOf(path)).toBe(undefined);
|
|
});
|
|
});
|
|
|
|
it('should apply partial arguments to function', () => {
|
|
const object = {
|
|
fn: function () {
|
|
return slice.call(arguments);
|
|
},
|
|
};
|
|
|
|
const methodOf = _.methodOf(object, 1, 2, 3);
|
|
|
|
lodashStable.each(['fn', ['fn']], (path) => {
|
|
expect(methodOf(path)).toEqual([1, 2, 3]);
|
|
});
|
|
});
|
|
|
|
it('should invoke deep property methods with the correct `this` binding', () => {
|
|
const object = {
|
|
a: {
|
|
b: function () {
|
|
return this.c;
|
|
},
|
|
c: 1,
|
|
},
|
|
};
|
|
const methodOf = _.methodOf(object);
|
|
|
|
lodashStable.each(['a.b', ['a', 'b']], (path) => {
|
|
expect(methodOf(path)).toBe(1);
|
|
});
|
|
});
|
|
});
|