-
Notifications
You must be signed in to change notification settings - Fork 30.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
inspector: allow --inspect=host:port from js
PR-URL: #13228 Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com> Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
- Loading branch information
1 parent
b3fb909
commit 9be8b63
Showing
9 changed files
with
193 additions
and
3 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
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
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,104 @@ | ||
'use strict'; | ||
const common = require('../common'); | ||
|
||
// Test inspector open()/close()/url() API. It uses ephemeral ports so can be | ||
// run safely in parallel. | ||
|
||
const assert = require('assert'); | ||
const fork = require('child_process').fork; | ||
const net = require('net'); | ||
const url = require('url'); | ||
|
||
common.skipIfInspectorDisabled(); | ||
|
||
if (process.env.BE_CHILD) | ||
return beChild(); | ||
|
||
const child = fork(__filename, {env: {BE_CHILD: 1}}); | ||
|
||
child.once('message', common.mustCall((msg) => { | ||
assert.strictEqual(msg.cmd, 'started'); | ||
|
||
child.send({cmd: 'open', args: [0]}); | ||
child.once('message', common.mustCall(firstOpen)); | ||
})); | ||
|
||
let firstPort; | ||
|
||
function firstOpen(msg) { | ||
assert.strictEqual(msg.cmd, 'url'); | ||
const port = url.parse(msg.url).port; | ||
ping(port, (err) => { | ||
assert.ifError(err); | ||
// Inspector is already open, and won't be reopened, so args don't matter. | ||
child.send({cmd: 'open', args: []}); | ||
child.once('message', common.mustCall(tryToOpenWhenOpen)); | ||
firstPort = port; | ||
}); | ||
} | ||
|
||
function tryToOpenWhenOpen(msg) { | ||
assert.strictEqual(msg.cmd, 'url'); | ||
const port = url.parse(msg.url).port; | ||
// Reopen didn't do anything, the port was already open, and has not changed. | ||
assert.strictEqual(port, firstPort); | ||
ping(port, (err) => { | ||
assert.ifError(err); | ||
child.send({cmd: 'close'}); | ||
child.once('message', common.mustCall(closeWhenOpen)); | ||
}); | ||
} | ||
|
||
function closeWhenOpen(msg) { | ||
assert.strictEqual(msg.cmd, 'url'); | ||
assert.strictEqual(msg.url, undefined); | ||
ping(firstPort, (err) => { | ||
assert(err); | ||
child.send({cmd: 'close'}); | ||
child.once('message', common.mustCall(tryToCloseWhenClosed)); | ||
}); | ||
} | ||
|
||
function tryToCloseWhenClosed(msg) { | ||
assert.strictEqual(msg.cmd, 'url'); | ||
assert.strictEqual(msg.url, undefined); | ||
child.send({cmd: 'open', args: []}); | ||
child.once('message', common.mustCall(reopenAfterClose)); | ||
} | ||
|
||
function reopenAfterClose(msg) { | ||
assert.strictEqual(msg.cmd, 'url'); | ||
const port = url.parse(msg.url).port; | ||
assert.notStrictEqual(port, firstPort); | ||
ping(port, (err) => { | ||
assert.ifError(err); | ||
process.exit(); | ||
}); | ||
} | ||
|
||
function ping(port, callback) { | ||
net.connect(port) | ||
.on('connect', function() { close(this); }) | ||
.on('error', function(err) { close(this, err); }); | ||
|
||
function close(self, err) { | ||
self.end(); | ||
self.on('close', () => callback(err)); | ||
} | ||
} | ||
|
||
function beChild() { | ||
const inspector = require('inspector'); | ||
|
||
process.send({cmd: 'started'}); | ||
|
||
process.on('message', (msg) => { | ||
if (msg.cmd === 'open') { | ||
inspector.open(...msg.args); | ||
} | ||
if (msg.cmd === 'close') { | ||
inspector.close(); | ||
} | ||
process.send({cmd: 'url', url: inspector.url()}); | ||
}); | ||
} |