2019-03-11 19:21:13 +01:00
|
|
|
import { test, runIfMain } from "./mod.ts";
|
|
|
|
import { bench, runBenchmarks } from "./bench.ts";
|
2019-02-12 16:55:01 +01:00
|
|
|
|
2019-03-11 19:21:13 +01:00
|
|
|
import "./bench_example.ts";
|
2019-02-12 16:55:01 +01:00
|
|
|
|
2019-04-24 13:41:23 +02:00
|
|
|
test(async function benching(): Promise<void> {
|
|
|
|
bench(function forIncrementX1e9(b): void {
|
2019-02-12 16:55:01 +01:00
|
|
|
b.start();
|
2019-03-05 11:53:35 +11:00
|
|
|
for (let i = 0; i < 1e9; i++);
|
2019-02-12 16:55:01 +01:00
|
|
|
b.stop();
|
|
|
|
});
|
|
|
|
|
2019-04-24 13:41:23 +02:00
|
|
|
bench(function forDecrementX1e9(b): void {
|
2019-02-12 16:55:01 +01:00
|
|
|
b.start();
|
2019-03-05 11:53:35 +11:00
|
|
|
for (let i = 1e9; i > 0; i--);
|
2019-02-12 16:55:01 +01:00
|
|
|
b.stop();
|
|
|
|
});
|
|
|
|
|
2019-04-24 13:41:23 +02:00
|
|
|
bench(async function forAwaitFetchDenolandX10(b): Promise<void> {
|
2019-02-12 16:55:01 +01:00
|
|
|
b.start();
|
2019-03-05 11:53:35 +11:00
|
|
|
for (let i = 0; i < 10; i++) {
|
2019-10-06 01:02:34 +09:00
|
|
|
const r = await fetch("https://deno.land/");
|
2019-03-31 00:22:33 +04:30
|
|
|
await r.text();
|
2019-02-12 16:55:01 +01:00
|
|
|
}
|
|
|
|
b.stop();
|
|
|
|
});
|
|
|
|
|
2019-04-24 13:41:23 +02:00
|
|
|
bench(async function promiseAllFetchDenolandX10(b): Promise<void> {
|
2019-02-12 16:55:01 +01:00
|
|
|
const urls = new Array(10).fill("https://deno.land/");
|
|
|
|
b.start();
|
2019-03-31 00:22:33 +04:30
|
|
|
await Promise.all(
|
2019-04-24 13:41:23 +02:00
|
|
|
urls.map(
|
|
|
|
async (denoland: string): Promise<void> => {
|
2019-10-06 01:02:34 +09:00
|
|
|
const r = await fetch(denoland);
|
2019-04-24 13:41:23 +02:00
|
|
|
await r.text();
|
|
|
|
}
|
|
|
|
)
|
2019-03-31 00:22:33 +04:30
|
|
|
);
|
2019-02-12 16:55:01 +01:00
|
|
|
b.stop();
|
|
|
|
});
|
|
|
|
|
|
|
|
bench({
|
|
|
|
name: "runs100ForIncrementX1e6",
|
|
|
|
runs: 100,
|
2019-04-24 13:41:23 +02:00
|
|
|
func(b): void {
|
2019-02-12 16:55:01 +01:00
|
|
|
b.start();
|
2019-03-05 11:53:35 +11:00
|
|
|
for (let i = 0; i < 1e6; i++);
|
2019-02-12 16:55:01 +01:00
|
|
|
b.stop();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2019-04-24 13:41:23 +02:00
|
|
|
bench(function throwing(b): void {
|
2019-02-12 16:55:01 +01:00
|
|
|
b.start();
|
|
|
|
// Throws bc the timer's stop method is never called
|
|
|
|
});
|
|
|
|
|
|
|
|
await runBenchmarks({ skip: /throw/ });
|
|
|
|
});
|
2019-03-11 19:21:13 +01:00
|
|
|
|
|
|
|
runIfMain(import.meta);
|