mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
115792dfde
This avoids piling up `'listening'` event listeners if `.bind()` fails repeatedly. Fixes: https://github.com/nodejs/node/issues/30209 PR-URL: https://github.com/nodejs/node/pull/30210 Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
28 lines
747 B
JavaScript
28 lines
747 B
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const dgram = require('dgram');
|
|
|
|
// Regression test for https://github.com/nodejs/node/issues/30209
|
|
// No warning should be emitted when re-trying `.bind()` on UDP sockets
|
|
// repeatedly.
|
|
|
|
process.on('warning', common.mustNotCall());
|
|
|
|
const reservePortSocket = dgram.createSocket('udp4');
|
|
reservePortSocket.bind(() => {
|
|
const { port } = reservePortSocket.address();
|
|
|
|
const newSocket = dgram.createSocket('udp4');
|
|
|
|
let errors = 0;
|
|
newSocket.on('error', common.mustCall(() => {
|
|
if (++errors < 20) {
|
|
newSocket.bind(port, common.mustNotCall());
|
|
} else {
|
|
newSocket.close();
|
|
reservePortSocket.close();
|
|
}
|
|
}, 20));
|
|
newSocket.bind(port, common.mustNotCall());
|
|
});
|