mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
f5ce6b1ebf
V8 considers gc(true) legacy, and the new signature is much more expressive. PR-URL: https://github.com/nodejs/node/pull/43493 Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: Gus Caplan <me@gus.host> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
35 lines
886 B
JavaScript
35 lines
886 B
JavaScript
'use strict';
|
|
// Flags: --expose-gc
|
|
|
|
// Note: This is a variant of test-net-write-fully-async-hex-string.js.
|
|
// This always worked, but it seemed appropriate to add a test that checks the
|
|
// behavior for Buffers, too.
|
|
const common = require('../common');
|
|
const net = require('net');
|
|
|
|
const data = Buffer.alloc(1000000);
|
|
|
|
const server = net.createServer(common.mustCall(function(conn) {
|
|
conn.resume();
|
|
})).listen(0, common.mustCall(function() {
|
|
const conn = net.createConnection(this.address().port, common.mustCall(() => {
|
|
let count = 0;
|
|
|
|
function writeLoop() {
|
|
if (count++ === 200) {
|
|
conn.destroy();
|
|
server.close();
|
|
return;
|
|
}
|
|
|
|
while (conn.write(Buffer.from(data)));
|
|
global.gc({ type: 'minor' });
|
|
// The buffer allocated above should still be alive.
|
|
}
|
|
|
|
conn.on('drain', writeLoop);
|
|
|
|
writeLoop();
|
|
}));
|
|
}));
|