2021-08-08 07:01:37 -04:00
|
|
|
const benchmark = require("benchmark");
|
|
|
|
const childProcess = require("child_process");
|
|
|
|
const minimist = require("minimist");
|
|
|
|
const path = require("path");
|
|
|
|
const minifiers = require("./minifiers");
|
|
|
|
const results = require("./results");
|
|
|
|
const tests = require("./tests");
|
2020-01-01 09:18:38 -05:00
|
|
|
|
2020-01-15 06:57:47 -05:00
|
|
|
const args = minimist(process.argv.slice(2));
|
|
|
|
const shouldRunRust = !!args.rust;
|
|
|
|
|
2020-01-09 06:40:04 -05:00
|
|
|
const cmd = (command, ...args) => {
|
2021-08-08 07:01:37 -04:00
|
|
|
const throwErr = (msg) => {
|
|
|
|
throw new Error(`${msg}\n ${command} ${args.join(" ")}`);
|
2020-01-09 06:40:04 -05:00
|
|
|
};
|
|
|
|
|
2021-08-08 07:01:37 -04:00
|
|
|
const { status, signal, error, stdout, stderr } = childProcess.spawnSync(
|
|
|
|
command,
|
|
|
|
args.map(String),
|
|
|
|
{
|
|
|
|
stdio: ["ignore", "pipe", "pipe"],
|
|
|
|
encoding: "utf8",
|
|
|
|
}
|
|
|
|
);
|
2020-01-09 06:40:04 -05:00
|
|
|
if (error) {
|
|
|
|
throwErr(error.message);
|
|
|
|
}
|
|
|
|
if (signal) {
|
|
|
|
throwErr(`Command exited with signal ${signal}`);
|
|
|
|
}
|
|
|
|
if (status !== 0) {
|
|
|
|
throwErr(`Command exited with status ${status}`);
|
|
|
|
}
|
|
|
|
if (stderr) {
|
|
|
|
throwErr(`stderr: ${stderr}`);
|
|
|
|
}
|
|
|
|
return stdout;
|
|
|
|
};
|
|
|
|
|
2021-08-08 07:01:37 -04:00
|
|
|
const fromEntries = (entries) => {
|
2020-01-09 06:40:04 -05:00
|
|
|
if (Object.fromEntries) return Object.fromEntries(entries);
|
|
|
|
const obj = {};
|
|
|
|
for (const [prop, val] of entries) obj[prop] = val;
|
|
|
|
return obj;
|
2020-01-01 09:18:38 -05:00
|
|
|
};
|
|
|
|
|
2021-08-08 07:01:37 -04:00
|
|
|
const runTest = (test) =>
|
|
|
|
new Promise((resolve, reject) => {
|
|
|
|
// Run JS libraries.
|
|
|
|
const suite = new benchmark.Suite();
|
|
|
|
for (const m of Object.keys(minifiers)) {
|
|
|
|
suite.add(m, {
|
|
|
|
defer: true,
|
|
|
|
fn(deferred) {
|
|
|
|
Promise.resolve(
|
|
|
|
minifiers[m](test.contentAsString, test.contentAsBuffer)
|
|
|
|
).then(() => deferred.resolve());
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
suite
|
|
|
|
.on("cycle", (event) => console.info(test.name, event.target.toString()))
|
|
|
|
.on("complete", () =>
|
|
|
|
resolve(fromEntries(suite.map((b) => [b.name, b.hz])))
|
|
|
|
)
|
|
|
|
.on("error", reject)
|
|
|
|
.run({ async: true });
|
|
|
|
});
|
2020-01-01 09:18:38 -05:00
|
|
|
|
2020-01-09 06:40:04 -05:00
|
|
|
(async () => {
|
2021-08-08 07:01:37 -04:00
|
|
|
const speeds = fromEntries(tests.map((t) => [t.name, {}]));
|
2020-01-09 06:40:04 -05:00
|
|
|
|
|
|
|
// Run Rust library.
|
2020-01-15 06:57:47 -05:00
|
|
|
if (shouldRunRust) {
|
2021-08-08 07:01:37 -04:00
|
|
|
for (const [testName, testOps] of JSON.parse(
|
|
|
|
cmd(
|
|
|
|
path.join(
|
|
|
|
__dirname,
|
|
|
|
"minify-html-bench",
|
|
|
|
"target",
|
|
|
|
"release",
|
|
|
|
"minify-html-bench"
|
|
|
|
),
|
|
|
|
"--iterations",
|
|
|
|
512,
|
|
|
|
"--tests",
|
|
|
|
path.join(__dirname, "tests")
|
|
|
|
)
|
|
|
|
)) {
|
|
|
|
Object.assign(speeds[testName], { ["minify-html"]: testOps });
|
2020-01-15 06:57:47 -05:00
|
|
|
}
|
2020-01-09 06:40:04 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
for (const t of tests) {
|
2020-01-18 09:14:30 -05:00
|
|
|
Object.assign(speeds[t.name], await runTest(t));
|
2020-01-09 06:40:04 -05:00
|
|
|
}
|
2020-01-18 09:14:30 -05:00
|
|
|
results.writeSpeedResults(speeds);
|
2020-01-09 06:40:04 -05:00
|
|
|
})();
|