node/test/parallel/test-fastutf8stream-end.js
James M Snell 5335c101a9 fs: port SonicBoom module to fs module as Utf8Stream
As a first step to porting portions of the pino structured
logger into the runtime, this commit ports the SonicBoom
module to the fs module as Utf8Stream.

This is a faithful port of the SonicBoom module with some
modern updates, such as converting to a Class and using
Symbol.dispose. The bulk of the implementation is unchanged
from the original.

PR-URL: https://github.com/nodejs/node/pull/58897
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Vinícius Lourenço Claro Cardoso <contact@viniciusl.com.br>
2025-07-28 20:27:07 -07:00

112 lines
2.8 KiB
JavaScript

'use strict';
const common = require('../common');
const tmpdir = require('../common/tmpdir');
const {
strictEqual,
} = require('node:assert');
const fs = require('node:fs');
const { Utf8Stream } = require('node:fs');
const { join } = require('node:path');
const { isMainThread } = require('node:worker_threads');
tmpdir.refresh();
let fileCounter = 0;
if (isMainThread) {
process.umask(0o000);
}
function getTempFile() {
return join(tmpdir.path, `fastutf8stream-${process.pid}-${Date.now()}-${fileCounter++}.log`);
}
runTests(false);
runTests(true);
function runTests(sync) {
{
const dest = getTempFile();
const stream = new Utf8Stream({ dest, minLength: 4096, sync });
stream.once('ready', common.mustCall(() => {
const after = `${dest}-moved`;
stream.reopen(after);
stream.write('after reopen\n');
stream.on('finish', common.mustCall(() => {
fs.readFile(after, 'utf8', common.mustSucceed((data) => {
strictEqual(data, 'after reopen\n');
}));
}));
stream.end();
}));
}
{
const dest = getTempFile();
const stream = new Utf8Stream({ dest, minLength: 4096, sync });
stream.once('ready', common.mustCall(() => {
stream.reopen(`${dest}-moved`);
const after = `${dest}-moved-moved`;
stream.reopen(after);
stream.write('after reopen\n');
stream.on('finish', common.mustCall(() => {
fs.readFile(after, 'utf8', common.mustSucceed((data) => {
strictEqual(data, 'after reopen\n');
}));
}));
stream.end();
}));
}
{
const dest = getTempFile();
const stream = new Utf8Stream({ dest, minLength: 4096, sync });
const after = dest + '-moved';
stream.reopen(after);
stream.write('after reopen\n');
stream.on('finish', common.mustCall(() => {
fs.readFile(after, 'utf8', common.mustSucceed((data) => {
strictEqual(data, 'after reopen\n');
}));
}));
stream.end();
}
{
const dest = getTempFile();
const stream = new Utf8Stream({ dest, sync });
const str = Buffer.alloc(10000).fill('a').toString();
let totalWritten = 0;
function writeData() {
if (totalWritten >= 10000) {
stream.end();
return;
}
const chunk = str.slice(totalWritten, totalWritten + 1000);
if (stream.write(chunk)) {
totalWritten += chunk.length;
setImmediate(common.mustCall(writeData));
} else {
stream.once('drain', common.mustCall(() => {
totalWritten += chunk.length;
setImmediate(common.mustCall(writeData));
}));
}
};
stream.on('finish', common.mustCall(() => {
fs.readFile(dest, 'utf8', common.mustSucceed((data) => {
strictEqual(data.length, 10000);
strictEqual(data, str);
}));
}));
writeData();
}
}