-
Notifications
You must be signed in to change notification settings - Fork 30.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
cluster: correctly handle relative unix socket paths
Relative unix sockets paths were previously interpreted relative to the master's CWD, which was inconsistent with non-cluster behavior. A test case has been added as well. Fixes: #16387
- Loading branch information
laino
committed
Jan 8, 2018
1 parent
17db46c
commit e9d6c4b
Showing
3 changed files
with
73 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
'use strict'; | ||
const common = require('../common'); | ||
const assert = require('assert'); | ||
const cluster = require('cluster'); | ||
const net = require('net'); | ||
const path = require('path'); | ||
const fs = require('fs'); | ||
|
||
// Ref: | ||
// https://github.com/nodejs/node/issues/16387 | ||
// https://github.com/nodejs/node/pull/16749 | ||
|
||
if (common.isWindows) | ||
common.skip('On Windows named pipes live in their own ' + | ||
'filesystem and don\'t have a ~100 byte limit'); | ||
|
||
// Choose a socket name such that the absolute path would exceed 100 bytes. | ||
const socketDir = './unix-socket-dir'; | ||
const socketName = 'A'.repeat(100 - socketDir.length - 1); | ||
|
||
// Make sure we're not in a weird environment | ||
assert.strictEqual(path.resolve(socketDir, socketName).length > 100, true, | ||
'absolute socket path should be longer than 100 bytes'); | ||
|
||
if (cluster.isMaster) { | ||
// ensure that the worker exits peacefully | ||
process.chdir(common.tmpDir); | ||
fs.mkdirSync(socketDir); | ||
cluster.fork().on('exit', common.mustCall(function(statusCode) { | ||
assert.strictEqual(statusCode, 0); | ||
|
||
assert.strictEqual( | ||
fs.existsSync(path.join(socketDir, socketName)), false, | ||
'Socket should be removed when the worker exits'); | ||
})); | ||
} else { | ||
process.chdir(socketDir); | ||
|
||
const server = net.createServer(common.mustNotCall()); | ||
|
||
server.listen(socketName, common.mustCall(function() { | ||
assert.strictEqual( | ||
fs.existsSync(socketName), true, | ||
'Socket created in CWD'); | ||
|
||
process.disconnect(); | ||
})); | ||
} |