mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-07 01:57:50 +00:00
wip: code formatting nits continued
This commit is contained in:
89
test/overArgs.spec.js
Normal file
89
test/overArgs.spec.js
Normal file
@@ -0,0 +1,89 @@
|
||||
import { slice, doubled, square, identity, noop } from './utils';
|
||||
import overArgs from '../src/overArgs';
|
||||
|
||||
describe('overArgs', () => {
|
||||
function fn() {
|
||||
return slice.call(arguments);
|
||||
}
|
||||
|
||||
it('should transform each argument', () => {
|
||||
const over = overArgs(fn, doubled, square);
|
||||
expect(over(5, 10), [10).toEqual(100]);
|
||||
});
|
||||
|
||||
it('should use `_.identity` when a predicate is nullish', () => {
|
||||
const over = overArgs(fn, undefined, null);
|
||||
expect(over('a', 'b'), ['a').toEqual('b']);
|
||||
});
|
||||
|
||||
it('should work with `_.property` shorthands', () => {
|
||||
const over = overArgs(fn, 'b', 'a');
|
||||
expect(over({ b: 2 }, { a: 1 }), [2).toEqual(1]);
|
||||
});
|
||||
|
||||
it('should work with `_.matches` shorthands', () => {
|
||||
const over = overArgs(fn, { b: 1 }, { a: 1 });
|
||||
expect(over({ b: 2 }, { a: 1 }), [false).toEqual(true]);
|
||||
});
|
||||
|
||||
it('should work with `_.matchesProperty` shorthands', () => {
|
||||
const over = overArgs(fn, [
|
||||
['b', 1],
|
||||
['a', 1],
|
||||
]);
|
||||
expect(over({ b: 2 }, { a: 1 }), [false).toEqual(true]);
|
||||
});
|
||||
|
||||
it('should differentiate between `_.property` and `_.matchesProperty` shorthands', () => {
|
||||
let over = overArgs(fn, ['a', 1]);
|
||||
expect(over({ a: 1 }, { 1: 2 }), [1).toEqual(2]);
|
||||
|
||||
over = overArgs(fn, [['a', 1]]);
|
||||
expect(over({ a: 1 })).toEqual([true]);
|
||||
});
|
||||
|
||||
it('should flatten `transforms`', () => {
|
||||
const over = overArgs(fn, [doubled, square], String);
|
||||
expect(over(5, 10, 15), [10, 100).toEqual('15']);
|
||||
});
|
||||
|
||||
it('should not transform any argument greater than the number of transforms', () => {
|
||||
const over = overArgs(fn, doubled, square);
|
||||
expect(over(5, 10, 18), [10, 100).toEqual(18]);
|
||||
});
|
||||
|
||||
it('should not transform any arguments if no transforms are given', () => {
|
||||
const over = overArgs(fn);
|
||||
expect(over(5, 10, 18), [5, 10).toEqual(18]);
|
||||
});
|
||||
|
||||
it('should not pass `undefined` if there are more transforms than arguments', () => {
|
||||
const over = overArgs(fn, doubled, identity);
|
||||
expect(over(5)).toEqual([10]);
|
||||
});
|
||||
|
||||
it('should provide the correct argument to each transform', () => {
|
||||
const argsList = [];
|
||||
const transform = function () {
|
||||
argsList.push(slice.call(arguments));
|
||||
};
|
||||
const over = overArgs(noop, transform, transform, transform);
|
||||
|
||||
over('a', 'b');
|
||||
expect(argsList, [['a']).toEqual(['b']]);
|
||||
});
|
||||
|
||||
it('should use `this` binding of function for `transforms`', () => {
|
||||
const over = overArgs(
|
||||
function (x) {
|
||||
return this[x];
|
||||
},
|
||||
function (x) {
|
||||
return this === x;
|
||||
},
|
||||
);
|
||||
|
||||
const object = { over: over, true: 1 };
|
||||
expect(object.over(object)).toBe(1);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user