node/test/parallel/test-dgram-setBroadcast.js
Rich Trott 78520fa472 test,dgram: add tests for setBroadcast()
The only tests for `setBroadcast()` (from the `dgram` module) were in
`test/internet` which means they almost never get run. This adds a
minimal test that can check JS-land functionality in `test/parallel`.

I also expanded a comment and did some minor formatting on the existing
`test/internet` test. If there were an easy and reliable way to check
for the BROADCAST flag on an interface, it's possible that a version of
the test could be moved to `test/sequential` or `test/parallel` once it
was modified to only use internal networks.

PR-URL: https://github.com/nodejs/node/pull/6750
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: James M Snell <jasnell@gmail.com>
2016-05-16 14:52:08 -07:00

40 lines
1004 B
JavaScript

'use strict';
const common = require('../common');
const assert = require('assert');
const dgram = require('dgram');
const setup = () => {
return dgram.createSocket({type: 'udp4', reuseAddr: true});
};
const teardown = (socket) => {
if (socket.close)
socket.close();
};
const runTest = (testCode, expectError) => {
const socket = setup();
const assertion = expectError ? assert.throws : assert.doesNotThrow;
const wrapped = () => { testCode(socket); };
assertion(wrapped, expectError);
teardown(socket);
};
// Should throw EBADF if socket is never bound.
runTest((socket) => { socket.setBroadcast(true); }, /EBADF/);
// Should not throw if broadcast set to false after binding.
runTest((socket) => {
socket.bind(common.PORT, common.localhostIPv4, () => {
socket.setBroadcast(false);
});
});
// Should not throw if broadcast set to true after binding.
runTest((socket) => {
socket.bind(common.PORT, common.localhostIPv4, () => {
socket.setBroadcast(true);
});
});