Browse Source

debugger: improve ESRCH error message

When using `iojs debug -p <pid>` with an invalid pid, the debugger
printed an internal error message because it wasn't smart enough
to figure out that the target process didn't exist.  Now it is.

PR-URL: https://github.com/nodejs/io.js/pull/1863
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Fedor Indutny <fedor@indutny.com>
Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com>
Reviewed-By: Yosuke Furukawa <yosuke.furukawa@gmail.com>
v2.3.1-release
Jackson Tian 10 years ago
committed by Ben Noordhuis
parent
commit
81029c639a
  1. 15
      lib/_debugger.js
  2. 39
      test/debugger/test-debugger-pid.js

15
lib/_debugger.js

@ -1639,7 +1639,16 @@ Interface.prototype.trySpawn = function(cb) {
} else if (this.args.length === 3) { } else if (this.args.length === 3) {
// `node debug -p pid` // `node debug -p pid`
if (this.args[1] === '-p' && /^\d+$/.test(this.args[2])) { if (this.args[1] === '-p' && /^\d+$/.test(this.args[2])) {
process._debugProcess(parseInt(this.args[2], 10)); const pid = parseInt(this.args[2], 10);
try {
process._debugProcess(pid);
} catch (e) {
if (e.code === 'ESRCH') {
console.error(`Target process: ${pid} doesn't exist.`);
process.exit(1);
}
throw e;
}
isRemote = true; isRemote = true;
} else { } else {
var match = this.args[1].match(/^--port=(\d+)$/); var match = this.args[1].match(/^--port=(\d+)$/);
@ -1704,8 +1713,8 @@ Interface.prototype.trySpawn = function(cb) {
function connectError() { function connectError() {
// If it's failed to connect 10 times then print failed message // If it's failed to connect 10 times then print failed message
if (connectionAttempts >= 10) { if (connectionAttempts >= 10) {
self.stdout.write(' failed, please retry\n'); console.error(' failed, please retry');
return; process.exit(1);
} }
setTimeout(attemptConnect, 500); setTimeout(attemptConnect, 500);
} }

39
test/debugger/test-debugger-pid.js

@ -0,0 +1,39 @@
'use strict';
var common = require('../common');
var assert = require('assert');
var spawn = require('child_process').spawn;
var port = common.PORT + 1337;
var buffer = '';
var expected = [];
var scriptToDebug = common.fixturesDir + '/empty.js';
function fail() {
assert(0); // `--debug-brk script.js` should not quit
}
// connect to debug agent
var interfacer = spawn(process.execPath, ['debug', '-p', '655555']);
console.error(process.execPath, 'debug', '-p', '655555');
interfacer.stdout.setEncoding('utf-8');
interfacer.stderr.setEncoding('utf-8');
var onData = function(data) {
data = (buffer + data).split('\n');
buffer = data.pop();
data.forEach(function(line) {
interfacer.emit('line', line);
});
};
interfacer.stdout.on('data', onData);
interfacer.stderr.on('data', onData);
interfacer.on('line', function(line) {
line = line.replace(/^(debug> *)+/, '');
var expected = 'Target process: 655555 doesn\'t exist.';
assert.ok(expected == line, 'Got unexpected line: ' + line);
});
interfacer.on('exit', function(code, signal) {
assert.ok(code == 1, 'Got unexpected code: ' + code);
});
Loading…
Cancel
Save