Ensure after n parameter is coerced from NaN to 0 (#4430)

* Enable after tests

* Ensure after n parameter is coerced from NaN to 0
This commit is contained in:
Luiz Américo
2019-08-22 11:46:46 -03:00
committed by John-David Dalton
parent 8b441a506b
commit 2cf08be625
3 changed files with 32 additions and 31 deletions

View File

@@ -19,6 +19,7 @@ function after(n, func) {
if (typeof func != 'function') {
throw new TypeError('Expected a function')
}
n = n || 0
return function(...args) {
if (--n < 1) {
return func.apply(this, args)

View File

@@ -1,31 +0,0 @@
import assert from 'assert';
import lodashStable from 'lodash';
import { _ } from './utils.js';
describe('after', function() {
function after(n, times) {
var count = 0;
lodashStable.times(times, _.after(n, function() { count++; }));
return count;
}
it('should create a function that invokes `func` after `n` calls', function() {
assert.strictEqual(after(5, 5), 1, 'after(n) should invoke `func` after being called `n` times');
assert.strictEqual(after(5, 4), 0, 'after(n) should not invoke `func` before being called `n` times');
assert.strictEqual(after(0, 0), 0, 'after(0) should not invoke `func` immediately');
assert.strictEqual(after(0, 1), 1, 'after(0) should invoke `func` when called once');
});
it('should coerce `n` values of `NaN` to `0`', function() {
assert.strictEqual(after(NaN, 1), 1);
});
it('should use `this` binding of function', function() {
var after = _.after(1, function() { return ++this.count; }),
object = { 'after': after, 'count': 0 };
object.after();
assert.strictEqual(object.after(), 2);
assert.strictEqual(object.count, 2);
});
});

31
test/after.test.js Normal file
View File

@@ -0,0 +1,31 @@
import assert from 'assert';
import lodashStable from 'lodash';
import after from '../after.js';
describe('after', function() {
function testAfter(n, times) {
var count = 0;
lodashStable.times(times, after(n, function() { count++; }));
return count;
}
it('should create a function that invokes `func` after `n` calls', function() {
assert.strictEqual(testAfter(5, 5), 1, 'after(n) should invoke `func` after being called `n` times');
assert.strictEqual(testAfter(5, 4), 0, 'after(n) should not invoke `func` before being called `n` times');
assert.strictEqual(testAfter(0, 0), 0, 'after(0) should not invoke `func` immediately');
assert.strictEqual(testAfter(0, 1), 1, 'after(0) should invoke `func` when called once');
});
it('should coerce `n` values of `NaN` to `0`', function() {
assert.strictEqual(testAfter(NaN, 1), 1);
});
it('should use `this` binding of function', function() {
var afterFn = after(1, function() { return ++this.count; }),
object = { 'after': afterFn, 'count': 0 };
object.after();
assert.strictEqual(object.after(), 2);
assert.strictEqual(object.count, 2);
});
});