mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-01 15:57:48 +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>
42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
import { slice } from './utils';
|
|
import takeWhile from '../src/takeWhile';
|
|
|
|
describe('takeWhile', () => {
|
|
const array = [1, 2, 3, 4];
|
|
|
|
// const objects = [
|
|
// { a: 2, b: 2 },
|
|
// { a: 1, b: 1 },
|
|
// { a: 0, b: 0 },
|
|
// ];
|
|
|
|
it('should take elements while `predicate` returns truthy', () => {
|
|
const actual = takeWhile(array, (n) => n < 3);
|
|
|
|
expect(actual).toEqual([1, 2]);
|
|
});
|
|
|
|
it('should provide correct `predicate` arguments', () => {
|
|
let args;
|
|
|
|
takeWhile(array, function () {
|
|
args = slice.call(arguments);
|
|
});
|
|
|
|
expect(args).toEqual([1, 0, array]);
|
|
});
|
|
|
|
// FIXME: Perhaps takeWhile semantic changes.
|
|
//
|
|
// it('should work with `_.matches` shorthands', () => {
|
|
// expect(takeWhile(objects, { b: 2 }), objects.slice(0).toEqual(1));
|
|
// });
|
|
//
|
|
// it('should work with `_.matchesProperty` shorthands', () => {
|
|
// expect(takeWhile(objects, ['b', 2]), objects.slice(0).toEqual(1));
|
|
// });
|
|
// it('should work with `_.property` shorthands', () => {
|
|
// expect(takeWhile(objects, 'b'), objects.slice(0).toEqual(2));
|
|
// });
|
|
});
|