-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathbenchmark.test.js
54 lines (50 loc) · 1.47 KB
/
benchmark.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
const {
effect,
handler,
resume,
run,
singleCallback,
} = require("../src");
const testEff = effect("test");
const newPromise = () =>
new Promise((resolve, reject) => setImmediate(resolve));
// const withTest1Handler = handler({
// test: (k) => resume(k),
// });
const withTest2Handler = handler({
test: (k) =>
singleCallback((done) => setImmediate(done)).chain((val) => resume(k, val)),
});
function eff(n) {
if (n < 1) return testEff();
return testEff().chain(() => eff(n - 1));
}
function p(n) {
if (n < 1) return newPromise();
return newPromise().then(() => p(n - 1));
}
describe("benchmarks", () => {
it("should run faster than promises and not stack overflow", async () => {
const promiseStartTime = performance.now();
await p(100000);
const promiseEndTime = performance.now();
const promiseTime = promiseEndTime - promiseStartTime;
// const test1StartTime = performance.now();
// await run(withTest1Handler(eff(100000)));
// const test1EndTime = performance.now();
// const test1Time = test1EndTime - test1StartTime;
const test2StartTime = performance.now();
await run(withTest2Handler(eff(100000)));
const test2EndTime = performance.now();
const test2Time = test2EndTime - test2StartTime;
// expect(test1Time).toBeLessThan(promiseTime);
expect(test2Time).toBeLessThan(promiseTime);
console.log(
"promise: ",
promiseTime,
"eff: ",
// test1Time,
test2Time,
);
});
});