%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
// Call fs.promises.writeFile over and over again really fast. // Then see how many times it got called. // Yes, this is a silly benchmark. Most benchmarks are silly. 'use strict'; const path = require('path'); const common = require('../common.js'); const fs = require('fs'); const assert = require('assert'); const tmpdir = require('../../test/common/tmpdir'); tmpdir.refresh(); const filename = path.resolve(tmpdir.path, `.removeme-benchmark-garbage-${process.pid}`); let filesWritten = 0; const bench = common.createBenchmark(main, { duration: [5], encodingType: ['buf', 'asc', 'utf'], size: [2, 1024, 65535, 1024 * 1024], concurrent: [1, 10] }); function main({ encodingType, duration, concurrent, size }) { let encoding; let chunk; switch (encodingType) { case 'buf': chunk = Buffer.alloc(size, 'b'); break; case 'asc': chunk = 'a'.repeat(size); encoding = 'ascii'; break; case 'utf': chunk = 'ü'.repeat(Math.ceil(size / 2)); encoding = 'utf8'; break; default: throw new Error(`invalid encodingType: ${encodingType}`); } let writes = 0; let benchEnded = false; bench.start(); setTimeout(() => { benchEnded = true; bench.end(writes); for (let i = 0; i < filesWritten; i++) { try { fs.unlinkSync(`${filename}-${i}`); } catch { // Continue regardless of error. } } process.exit(0); }, duration * 1000); function write() { fs.promises.writeFile(`${filename}-${filesWritten++}`, chunk, encoding) .then(() => afterWrite()) .catch((err) => afterWrite(err)); } function afterWrite(er) { if (er) { if (er.code === 'ENOENT') { // Only OK if unlinked by the timer from main. assert.ok(benchEnded); return; } throw er; } writes++; if (!benchEnded) write(); } while (concurrent--) write(); }