2023-02-20 10:35:04 -05:00
|
|
|
|
// deno-fmt-ignore-file
|
|
|
|
|
// deno-lint-ignore-file
|
|
|
|
|
|
|
|
|
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
2024-11-25 08:35:53 -05:00
|
|
|
|
// Taken from Node 20.11.1
|
2024-04-02 18:24:55 -04:00
|
|
|
|
// This file is automatically generated by `tests/node_compat/runner/setup.ts`. Do not modify this file manually.
|
2023-02-20 10:35:04 -05:00
|
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
const common = require('../common');
|
|
|
|
|
const fixtures = require('../common/fixtures');
|
|
|
|
|
const assert = require('assert');
|
|
|
|
|
const fs = require('fs');
|
|
|
|
|
|
|
|
|
|
// Test that concurrent file read streams don’t interfere with each other’s
|
|
|
|
|
// contents, and that the chunks generated by the reads only retain a
|
|
|
|
|
// 'reasonable' amount of memory.
|
|
|
|
|
|
|
|
|
|
// Refs: https://github.com/nodejs/node/issues/21967
|
|
|
|
|
|
|
|
|
|
const filename = fixtures.path('loop.js'); // Some small non-homogeneous file.
|
|
|
|
|
const content = fs.readFileSync(filename);
|
|
|
|
|
|
|
|
|
|
const N = 2000;
|
|
|
|
|
let started = 0;
|
|
|
|
|
let done = 0;
|
|
|
|
|
|
|
|
|
|
const arrayBuffers = new Set();
|
|
|
|
|
|
|
|
|
|
function startRead() {
|
|
|
|
|
++started;
|
|
|
|
|
const chunks = [];
|
|
|
|
|
fs.createReadStream(filename)
|
|
|
|
|
.on('data', (chunk) => {
|
|
|
|
|
chunks.push(chunk);
|
|
|
|
|
arrayBuffers.add(chunk.buffer);
|
|
|
|
|
})
|
|
|
|
|
.on('end', common.mustCall(() => {
|
|
|
|
|
if (started < N)
|
|
|
|
|
startRead();
|
|
|
|
|
assert.deepStrictEqual(Buffer.concat(chunks), content);
|
|
|
|
|
if (++done === N) {
|
|
|
|
|
const retainedMemory =
|
|
|
|
|
[...arrayBuffers].map((ab) => ab.byteLength).reduce((a, b) => a + b);
|
|
|
|
|
assert(retainedMemory / (N * content.length) <= 3,
|
|
|
|
|
`Retaining ${retainedMemory} bytes in ABs for ${N} ` +
|
|
|
|
|
`chunks of size ${content.length}`);
|
|
|
|
|
}
|
|
|
|
|
}));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Don’t start the reads all at once – that way we would have to allocate
|
|
|
|
|
// a large amount of memory upfront.
|
|
|
|
|
for (let i = 0; i < 6; ++i)
|
|
|
|
|
startRead();
|