2023-05-04 08:11:04 -07:00
|
|
|
#!/usr/bin/env ts-node
|
|
|
|
/**
|
|
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
|
|
|
*
|
|
|
|
* @format
|
|
|
|
*/
|
|
|
|
|
2023-05-09 15:35:42 -07:00
|
|
|
import path from 'path';
|
2023-05-04 08:11:04 -07:00
|
|
|
|
2023-05-09 22:21:01 -07:00
|
|
|
import YogaAsmjs from 'yoga-layout/asmjs-sync';
|
|
|
|
import YogaWasm from 'yoga-layout/wasm-sync';
|
|
|
|
|
2023-05-04 08:11:04 -07:00
|
|
|
const WARMUP_ITERATIONS = 3;
|
|
|
|
const BENCHMARK_ITERATIONS = 10;
|
|
|
|
|
|
|
|
const testFiles = process.argv.slice(2);
|
|
|
|
|
|
|
|
const testResults = new Map<string, Map<string, number>>();
|
|
|
|
|
2023-05-09 15:35:42 -07:00
|
|
|
for (const type of ['asmjs', 'wasm']) {
|
2023-05-09 22:21:01 -07:00
|
|
|
globalThis.Yoga = type === 'asmjs' ? YogaAsmjs : YogaWasm;
|
2023-05-04 08:11:04 -07:00
|
|
|
|
|
|
|
for (const file of testFiles) {
|
|
|
|
globalThis.YGBENCHMARK = (name: string, fn: () => void) => {
|
|
|
|
let testEntry = testResults.get(name);
|
|
|
|
|
|
|
|
if (testEntry === undefined)
|
|
|
|
testResults.set(name, (testEntry = new Map()));
|
|
|
|
|
|
|
|
for (let t = 0; t < WARMUP_ITERATIONS; ++t) fn();
|
|
|
|
|
|
|
|
const start = Date.now();
|
|
|
|
|
|
|
|
for (let t = 0; t < BENCHMARK_ITERATIONS; ++t) fn();
|
|
|
|
|
|
|
|
const end = Date.now();
|
|
|
|
|
|
|
|
testEntry.set(type, (end - start) / BENCHMARK_ITERATIONS);
|
|
|
|
};
|
|
|
|
|
|
|
|
const modulePath = path.resolve(file);
|
|
|
|
|
2023-05-09 15:35:42 -07:00
|
|
|
delete require.cache[require.resolve('../tools/globals')];
|
2023-05-04 08:11:04 -07:00
|
|
|
delete require.cache[modulePath];
|
|
|
|
require(modulePath);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log(
|
2023-05-09 15:35:42 -07:00
|
|
|
`Note: those tests are independants; there is no time relation to be expected between them`,
|
2023-05-04 08:11:04 -07:00
|
|
|
);
|
|
|
|
|
|
|
|
for (const [name, results] of testResults) {
|
|
|
|
console.log();
|
|
|
|
|
|
|
|
const min = Math.min(Infinity, ...results.values());
|
|
|
|
|
|
|
|
console.log(name);
|
|
|
|
|
|
|
|
for (const [type, result] of results) {
|
|
|
|
console.log(
|
2023-05-09 15:35:42 -07:00
|
|
|
` - ${type}: ${result}ms (${Math.round((result / min) * 10000) / 100}%)`,
|
2023-05-04 08:11:04 -07:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|