mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-07 18:07:49 +00:00
wip: migrate to bun
This commit is contained in:
294
test/debounce.spec.ts
Normal file
294
test/debounce.spec.ts
Normal file
@@ -0,0 +1,294 @@
|
||||
import assert from 'node:assert';
|
||||
import { identity, argv, isPhantom, push } from './utils';
|
||||
import debounce from '../src/debounce';
|
||||
|
||||
describe('debounce', () => {
|
||||
it('should debounce a function', (done) => {
|
||||
let callCount = 0;
|
||||
|
||||
const debounced = debounce((value) => {
|
||||
++callCount;
|
||||
return value;
|
||||
}, 32);
|
||||
|
||||
const results = [debounced('a'), debounced('b'), debounced('c')];
|
||||
assert.deepStrictEqual(results, [undefined, undefined, undefined]);
|
||||
assert.strictEqual(callCount, 0);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 1);
|
||||
|
||||
const results = [debounced('d'), debounced('e'), debounced('f')];
|
||||
assert.deepStrictEqual(results, ['c', 'c', 'c']);
|
||||
assert.strictEqual(callCount, 1);
|
||||
}, 128);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 2);
|
||||
done();
|
||||
}, 256);
|
||||
});
|
||||
|
||||
it('subsequent debounced calls return the last `func` result', (done) => {
|
||||
const debounced = debounce(identity, 32);
|
||||
debounced('a');
|
||||
|
||||
setTimeout(() => {
|
||||
assert.notStrictEqual(debounced('b'), 'b');
|
||||
}, 64);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.notStrictEqual(debounced('c'), 'c');
|
||||
done();
|
||||
}, 128);
|
||||
});
|
||||
|
||||
it('should not immediately call `func` when `wait` is `0`', (done) => {
|
||||
let callCount = 0,
|
||||
debounced = debounce(() => {
|
||||
++callCount;
|
||||
}, 0);
|
||||
|
||||
debounced();
|
||||
debounced();
|
||||
assert.strictEqual(callCount, 0);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 1);
|
||||
done();
|
||||
}, 5);
|
||||
});
|
||||
|
||||
it('should apply default options', (done) => {
|
||||
let callCount = 0,
|
||||
debounced = debounce(
|
||||
() => {
|
||||
callCount++;
|
||||
},
|
||||
32,
|
||||
{},
|
||||
);
|
||||
|
||||
debounced();
|
||||
assert.strictEqual(callCount, 0);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 1);
|
||||
done();
|
||||
}, 64);
|
||||
});
|
||||
|
||||
it('should support a `leading` option', (done) => {
|
||||
const callCounts = [0, 0];
|
||||
|
||||
const withLeading = debounce(
|
||||
() => {
|
||||
callCounts[0]++;
|
||||
},
|
||||
32,
|
||||
{ leading: true },
|
||||
);
|
||||
|
||||
const withLeadingAndTrailing = debounce(
|
||||
() => {
|
||||
callCounts[1]++;
|
||||
},
|
||||
32,
|
||||
{ leading: true },
|
||||
);
|
||||
|
||||
withLeading();
|
||||
assert.strictEqual(callCounts[0], 1);
|
||||
|
||||
withLeadingAndTrailing();
|
||||
withLeadingAndTrailing();
|
||||
assert.strictEqual(callCounts[1], 1);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.deepStrictEqual(callCounts, [1, 2]);
|
||||
|
||||
withLeading();
|
||||
assert.strictEqual(callCounts[0], 2);
|
||||
|
||||
done();
|
||||
}, 64);
|
||||
});
|
||||
|
||||
it('subsequent leading debounced calls return the last `func` result', (done) => {
|
||||
const debounced = debounce(identity, 32, { leading: true, trailing: false }),
|
||||
results = [debounced('a'), debounced('b')];
|
||||
|
||||
assert.deepStrictEqual(results, ['a', 'a']);
|
||||
|
||||
setTimeout(() => {
|
||||
const results = [debounced('c'), debounced('d')];
|
||||
assert.deepStrictEqual(results, ['c', 'c']);
|
||||
done();
|
||||
}, 64);
|
||||
});
|
||||
|
||||
it('should support a `trailing` option', (done) => {
|
||||
let withCount = 0,
|
||||
withoutCount = 0;
|
||||
|
||||
const withTrailing = debounce(
|
||||
() => {
|
||||
withCount++;
|
||||
},
|
||||
32,
|
||||
{ trailing: true },
|
||||
);
|
||||
|
||||
const withoutTrailing = debounce(
|
||||
() => {
|
||||
withoutCount++;
|
||||
},
|
||||
32,
|
||||
{ trailing: false },
|
||||
);
|
||||
|
||||
withTrailing();
|
||||
assert.strictEqual(withCount, 0);
|
||||
|
||||
withoutTrailing();
|
||||
assert.strictEqual(withoutCount, 0);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(withCount, 1);
|
||||
assert.strictEqual(withoutCount, 0);
|
||||
done();
|
||||
}, 64);
|
||||
});
|
||||
|
||||
it('should support a `maxWait` option', (done) => {
|
||||
let callCount = 0;
|
||||
|
||||
const debounced = debounce(
|
||||
(value) => {
|
||||
++callCount;
|
||||
return value;
|
||||
},
|
||||
32,
|
||||
{ maxWait: 64 },
|
||||
);
|
||||
|
||||
debounced();
|
||||
debounced();
|
||||
assert.strictEqual(callCount, 0);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 1);
|
||||
debounced();
|
||||
debounced();
|
||||
assert.strictEqual(callCount, 1);
|
||||
}, 128);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 2);
|
||||
done();
|
||||
}, 256);
|
||||
});
|
||||
|
||||
it('should support `maxWait` in a tight loop', (done) => {
|
||||
let limit = argv || isPhantom ? 1000 : 320,
|
||||
withCount = 0,
|
||||
withoutCount = 0;
|
||||
|
||||
const withMaxWait = debounce(
|
||||
() => {
|
||||
withCount++;
|
||||
},
|
||||
64,
|
||||
{ maxWait: 128 },
|
||||
);
|
||||
|
||||
const withoutMaxWait = debounce(() => {
|
||||
withoutCount++;
|
||||
}, 96);
|
||||
|
||||
const start = +new Date();
|
||||
while (new Date() - start < limit) {
|
||||
withMaxWait();
|
||||
withoutMaxWait();
|
||||
}
|
||||
const actual = [Boolean(withoutCount), Boolean(withCount)];
|
||||
setTimeout(() => {
|
||||
assert.deepStrictEqual(actual, [false, true]);
|
||||
done();
|
||||
}, 1);
|
||||
});
|
||||
|
||||
it('should queue a trailing call for subsequent debounced calls after `maxWait`', (done) => {
|
||||
let callCount = 0;
|
||||
|
||||
const debounced = debounce(
|
||||
() => {
|
||||
++callCount;
|
||||
},
|
||||
200,
|
||||
{ maxWait: 200 },
|
||||
);
|
||||
|
||||
debounced();
|
||||
|
||||
setTimeout(debounced, 190);
|
||||
setTimeout(debounced, 200);
|
||||
setTimeout(debounced, 210);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 2);
|
||||
done();
|
||||
}, 500);
|
||||
});
|
||||
|
||||
it('should cancel `maxDelayed` when `delayed` is invoked', (done) => {
|
||||
let callCount = 0;
|
||||
|
||||
const debounced = debounce(
|
||||
() => {
|
||||
callCount++;
|
||||
},
|
||||
32,
|
||||
{ maxWait: 64 },
|
||||
);
|
||||
|
||||
debounced();
|
||||
|
||||
setTimeout(() => {
|
||||
debounced();
|
||||
assert.strictEqual(callCount, 1);
|
||||
}, 128);
|
||||
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 2);
|
||||
done();
|
||||
}, 192);
|
||||
});
|
||||
|
||||
it('should invoke the trailing call with the correct arguments and `this` binding', (done) => {
|
||||
let actual,
|
||||
callCount = 0,
|
||||
object = {};
|
||||
|
||||
const debounced = debounce(
|
||||
function (value) {
|
||||
actual = [this];
|
||||
push.apply(actual, arguments);
|
||||
return ++callCount != 2;
|
||||
},
|
||||
32,
|
||||
{ leading: true, maxWait: 64 },
|
||||
);
|
||||
|
||||
while (true) {
|
||||
if (!debounced.call(object, 'a')) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
setTimeout(() => {
|
||||
assert.strictEqual(callCount, 2);
|
||||
assert.deepStrictEqual(actual, [object, 'a']);
|
||||
done();
|
||||
}, 64);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user