2023-02-24 02:11:51 +08:00
|
|
|
'use strict';
|
|
|
|
const common = require('../common.js');
|
|
|
|
const path = require('path');
|
|
|
|
|
|
|
|
const configs = {
|
|
|
|
n: [1e5],
|
|
|
|
concurrent: [1, 10],
|
|
|
|
};
|
|
|
|
|
|
|
|
const rootPath = path.resolve(__dirname, '../../..');
|
|
|
|
|
|
|
|
const options = {
|
|
|
|
flags: [
|
|
|
|
'--experimental-permission',
|
|
|
|
`--allow-fs-read=${rootPath}`,
|
2024-05-19 04:37:31 +08:00
|
|
|
'--allow-child-process',
|
2023-02-24 02:11:51 +08:00
|
|
|
],
|
|
|
|
};
|
|
|
|
|
|
|
|
const bench = common.createBenchmark(main, configs, options);
|
|
|
|
|
2023-04-05 01:14:04 +08:00
|
|
|
// This is a naive benchmark and might not demonstrate real-world use cases.
|
|
|
|
// New benchmarks will be created once the permission model config is available
|
|
|
|
// through a config file.
|
2023-02-24 02:11:51 +08:00
|
|
|
async function main(conf) {
|
|
|
|
const benchmarkDir = path.join(__dirname, '../..');
|
|
|
|
bench.start();
|
|
|
|
|
|
|
|
for (let i = 0; i < conf.n; i++) {
|
|
|
|
// Valid file in a sequence of denied files
|
|
|
|
process.permission.has('fs.read', benchmarkDir + '/valid-file');
|
|
|
|
// Denied file
|
|
|
|
process.permission.has('fs.read', __filename);
|
|
|
|
// Valid file a granted directory
|
|
|
|
process.permission.has('fs.read', '/tmp/example');
|
|
|
|
}
|
|
|
|
|
|
|
|
bench.end(conf.n);
|
|
|
|
}
|