node/test/parallel/test-dgram-create-socket-handle-fd.js
Daniel Bevenius 57d98bc732 src: move process.binding('tcp_wrap') to internal
This commit makes the tcp_wrap builtin an internal builtin, and
changes usage of the builtin from using process.binding('tcp_wrap')
to use internalBinding instead.

Refs: https://github.com/nodejs/node/issues/22160

PR-URL: https://github.com/nodejs/node/pull/22432
Refs: https://github.com/nodejs/node/issues/22160
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com>
2018-08-24 09:10:38 +02:00

45 lines
1.3 KiB
JavaScript

// Flags: --expose-internals
'use strict';
const common = require('../common');
if (common.isWindows)
common.skip('Does not support binding fd on Windows');
const assert = require('assert');
const dgram = require('dgram');
const { UDP } = process.binding('udp_wrap');
const { internalBinding } = require('internal/test/binding');
const { TCP, constants } = internalBinding('tcp_wrap');
const _createSocketHandle = dgram._createSocketHandle;
// Return a negative number if the "existing fd" is invalid.
{
const err = _createSocketHandle(common.localhostIPv4, 0, 'udp4', 42);
assert(err < 0);
}
// Return a negative number if the type of fd is not "UDP".
{
// Create a handle with fd.
const rawHandle = new UDP();
const err = rawHandle.bind(common.localhostIPv4, 0, 0);
assert(err >= 0, String(err));
assert.notStrictEqual(rawHandle.fd, -1);
const handle = _createSocketHandle(null, 0, 'udp4', rawHandle.fd);
assert(handle instanceof UDP);
assert.strictEqual(typeof handle.fd, 'number');
assert(handle.fd > 0);
}
// Create a bound handle.
{
const rawHandle = new TCP(constants.SOCKET);
const err = rawHandle.listen();
assert(err >= 0, String(err));
assert.notStrictEqual(rawHandle.fd, -1);
const handle = _createSocketHandle(null, 0, 'udp4', rawHandle.fd);
assert(handle < 0);
rawHandle.close();
}