mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
f29762f4dd
Enable linting for the test directory. A number of changes was made so all tests conform the current rules used by lib and src directories. The only exception for tests is that unreachable (dead) code is allowed. test-fs-non-number-arguments-throw had to be excluded from the changes because of a weird issue on Windows CI. PR-URL: https://github.com/nodejs/io.js/pull/1721 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
217 lines
5.9 KiB
JavaScript
217 lines
5.9 KiB
JavaScript
'use strict';
|
|
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);
|
|
});
|