node/test/simple/test-debugger-repl.js

140 lines
3.5 KiB
JavaScript

// Copyright Joyent, Inc. and other Node contributors.
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to permit
// persons to whom the Software is furnished to do so, subject to the
// following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
// USE OR OTHER DEALINGS IN THE SOFTWARE.
var common = require('../common');
var assert = require('assert');
var spawn = require('child_process').spawn;
var debug = require('_debugger');
var code = require('fs').readFileSync(common.fixturesDir + '/breakpoints.js');
var child = spawn(process.execPath, ['debug', '-e', code]);
var buffer = '';
child.stdout.setEncoding('utf-8');
child.stdout.on('data', function(data) {
data = (buffer + data.toString()).split(/\n/g);
buffer = data.pop();
data.forEach(function(line) {
child.emit('line', line);
});
});
child.stderr.pipe(process.stdout);
var expected = [];
child.on('line', function(line) {
assert.ok(expected.length > 0, 'Got unexpected line: ' + line);
var expectedLine = expected[0].lines.shift();
assert.equal(line, expectedLine);
if (expected[0].lines.length === 0) {
var callback = expected[0].callback;
expected.shift();
callback && callback();
}
});
function addTest(input, output) {
function next() {
if (expected.length > 0) {
child.stdin.write(expected[0].input + '\n');
console.log('---');
console.log('>>', expected[0].input);
} else {
finish();
}
};
expected.push({input: input, lines: output, callback: next});
};
// Initial lines
addTest(null, [
"debug> \b< debugger listening on port 5858",
"debug> \bconnecting... ok",
"debug> \bbreak in [unnamed]:3",
"\b 1 ",
"\b 2 debugger;",
"\b 3 debugger;",
"\b 4 function a(x) {",
"\b 5 var i = 10;"
]);
// Next
addTest('n', [
"debug> debug> debug> \bbreak in [unnamed]:13",
"\b 11 return ['hello', 'world'].join(' ');",
"\b 12 };",
"\b 13 a();",
"\b 14 a(1);",
"\b 15 b();"
]);
// Continue
addTest('c', [
"debug> debug> debug> \bbreak in [unnamed]:7",
"\b 5 var i = 10;",
"\b 6 while (--i != 0);",
"\b 7 debugger;",
"\b 8 return i;",
"\b 9 };"
]);
// Step out
addTest('o', [
"debug> debug> debug> \bbreak in [unnamed]:14",
"\b 12 };",
"\b 13 a();",
"\b 14 a(1);",
"\b 15 b();",
"\b 16 b();"
]);
function finish() {
process.exit(0);
};
function quit() {
if (quit.called) return;
quit.called = true;
child.stdin.write('quit');
};
setTimeout(function() {
throw new Error('timeout!');
}, 5000);
process.once('uncaughtException', function(e) {
quit();
console.error(e.toString());
process.exit(1);
});
process.on('exit', function(code) {
quit();
if (code === 0) {
assert.equal(expected.length, 0);
}
});