mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
3e1b1dd4a9
The copyright and license notice is already in the LICENSE file. There is no justifiable reason to also require that it be included in every file, since the individual files are not individually distributed except as part of the entire package.
216 lines
5.9 KiB
JavaScript
216 lines
5.9 KiB
JavaScript
process.env.NODE_DEBUGGER_TIMEOUT = 2000;
|
|
var common = require('../common');
|
|
var assert = require('assert');
|
|
var debug = require('_debugger');
|
|
|
|
var debugPort = common.PORT + 1337;
|
|
debug.port = debugPort;
|
|
var spawn = require('child_process').spawn;
|
|
|
|
setTimeout(function() {
|
|
if (nodeProcess) nodeProcess.kill('SIGTERM');
|
|
throw new Error('timeout');
|
|
}, 10000).unref();
|
|
|
|
|
|
var resCount = 0;
|
|
var p = new debug.Protocol();
|
|
p.onResponse = function(res) {
|
|
resCount++;
|
|
};
|
|
|
|
p.execute('Type: connect\r\n' +
|
|
'V8-Version: 3.0.4.1\r\n' +
|
|
'Protocol-Version: 1\r\n' +
|
|
'Embedding-Host: node v0.3.3-pre\r\n' +
|
|
'Content-Length: 0\r\n\r\n');
|
|
assert.equal(1, resCount);
|
|
|
|
// Make sure split messages go in.
|
|
|
|
var parts = [];
|
|
parts.push('Content-Length: 336\r\n');
|
|
assert.equal(21, parts[0].length);
|
|
parts.push('\r\n');
|
|
assert.equal(2, parts[1].length);
|
|
var bodyLength = 0;
|
|
|
|
parts.push('{"seq":12,"type":"event","event":"break","body":' +
|
|
'{"invocationText":"#<a Server>');
|
|
assert.equal(78, parts[2].length);
|
|
bodyLength += parts[2].length;
|
|
|
|
parts.push('.[anonymous](req=#<an IncomingMessage>, ' +
|
|
'res=#<a ServerResponse>)","sourceLine"');
|
|
assert.equal(78, parts[3].length);
|
|
bodyLength += parts[3].length;
|
|
|
|
parts.push(':45,"sourceColumn":4,"sourceLineText":" debugger;",' +
|
|
'"script":{"id":24,"name":"/home/ryan/projects/node/' +
|
|
'benchmark/http_simple.js","lineOffset":0,"columnOffset":0,' +
|
|
'"lineCount":98}}}');
|
|
assert.equal(180, parts[4].length);
|
|
bodyLength += parts[4].length;
|
|
|
|
assert.equal(336, bodyLength);
|
|
|
|
for (var i = 0; i < parts.length; i++) {
|
|
p.execute(parts[i]);
|
|
}
|
|
assert.equal(2, resCount);
|
|
|
|
|
|
// Make sure that if we get backed up, we still manage to get all the
|
|
// messages
|
|
var d = 'Content-Length: 466\r\n\r\n' +
|
|
'{"seq":10,"type":"event","event":"afterCompile","success":true,' +
|
|
'"body":{"script":{"handle":1,"type":"script","name":"dns.js",' +
|
|
'"id":34,"lineOffset":0,"columnOffset":0,"lineCount":241,' +
|
|
'"sourceStart":"(function (module, exports, require) {' +
|
|
'var dns = process.binding(\'cares\')' +
|
|
';\\nvar ne","sourceLength":6137,"scriptType":2,"compilationType":0,' +
|
|
'"context":{"ref":0},"text":"dns.js (lines: 241)"}},"refs":' +
|
|
'[{"handle":0' +
|
|
',"type":"context","text":"#<a ContextMirror>"}],"running":true}' +
|
|
'Content-Length: 119\r\n\r\n' +
|
|
'{"seq":11,"type":"event","event":"scriptCollected","success":true,' +
|
|
'"body":{"script":{"id":26}},"refs":[],"running":true}';
|
|
p.execute(d);
|
|
assert.equal(4, resCount);
|
|
|
|
var expectedConnections = 0;
|
|
var tests = [];
|
|
function addTest(cb) {
|
|
expectedConnections++;
|
|
tests.push(cb);
|
|
}
|
|
|
|
addTest(function(client, done) {
|
|
console.error('requesting version');
|
|
client.reqVersion(function(err, v) {
|
|
assert.ok(!err);
|
|
console.log('version: %s', v);
|
|
assert.equal(process.versions.v8, v);
|
|
done();
|
|
});
|
|
});
|
|
|
|
addTest(function(client, done) {
|
|
console.error('requesting scripts');
|
|
client.reqScripts(function(err) {
|
|
assert.ok(!err);
|
|
console.error('got %d scripts', Object.keys(client.scripts).length);
|
|
|
|
var foundMainScript = false;
|
|
for (var k in client.scripts) {
|
|
var script = client.scripts[k];
|
|
if (script && script.name === 'node.js') {
|
|
foundMainScript = true;
|
|
break;
|
|
}
|
|
}
|
|
assert.ok(foundMainScript);
|
|
done();
|
|
});
|
|
});
|
|
|
|
addTest(function(client, done) {
|
|
console.error('eval 2+2');
|
|
client.reqEval('2+2', function(err, res) {
|
|
console.error(res);
|
|
assert.ok(!err);
|
|
assert.equal('4', res.text);
|
|
assert.equal(4, res.value);
|
|
done();
|
|
});
|
|
});
|
|
|
|
|
|
var connectCount = 0;
|
|
var script = 'setTimeout(function () { console.log("blah"); });' +
|
|
'setInterval(function () {}, 1000000);';
|
|
|
|
var nodeProcess;
|
|
|
|
function doTest(cb, done) {
|
|
var args = ['--debug=' + debugPort, '-e', script];
|
|
nodeProcess = spawn(process.execPath, args);
|
|
|
|
nodeProcess.stdout.once('data', function(c) {
|
|
console.log('>>> new node process: %d', nodeProcess.pid);
|
|
var failed = true;
|
|
try {
|
|
process._debugProcess(nodeProcess.pid);
|
|
failed = false;
|
|
} finally {
|
|
// At least TRY not to leave zombie procs if this fails.
|
|
if (failed)
|
|
nodeProcess.kill('SIGTERM');
|
|
}
|
|
console.log('>>> starting debugger session');
|
|
});
|
|
|
|
var didTryConnect = false;
|
|
nodeProcess.stderr.setEncoding('utf8');
|
|
var b = '';
|
|
nodeProcess.stderr.on('data', function(data) {
|
|
console.error('got stderr data %j', data);
|
|
nodeProcess.stderr.resume();
|
|
b += data;
|
|
if (didTryConnect === false && b.match(/Debugger listening on port/)) {
|
|
didTryConnect = true;
|
|
|
|
// The timeout is here to expose a race in the bootstrap process.
|
|
// Without the early SIGUSR1 debug handler, it effectively results
|
|
// in an infinite ECONNREFUSED loop.
|
|
setTimeout(tryConnect, 100);
|
|
|
|
function tryConnect() {
|
|
// Wait for some data before trying to connect
|
|
var c = new debug.Client();
|
|
console.error('>>> connecting...');
|
|
c.connect(debug.port);
|
|
c.on('break', function(brk) {
|
|
c.reqContinue(function() {});
|
|
});
|
|
c.on('ready', function() {
|
|
connectCount++;
|
|
console.log('ready!');
|
|
cb(c, function() {
|
|
c.end();
|
|
c.on('end', function() {
|
|
console.error(
|
|
'>>> killing node process %d\n\n',
|
|
nodeProcess.pid);
|
|
nodeProcess.kill();
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
c.on('error', function(err) {
|
|
if (err.code !== 'ECONNREFUSED') throw err;
|
|
setTimeout(tryConnect, 10);
|
|
});
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
function run() {
|
|
var t = tests[0];
|
|
if (!t) return;
|
|
|
|
doTest(t, function() {
|
|
tests.shift();
|
|
run();
|
|
});
|
|
}
|
|
|
|
run();
|
|
|
|
process.on('exit', function(code) {
|
|
if (!code)
|
|
assert.equal(expectedConnections, connectCount);
|
|
});
|