diff options
author | cjihrig <cjihrig@gmail.com> | 2016-05-16 15:41:37 -0400 |
---|---|---|
committer | Jeremiah Senkpiel <fishrock123@rocketmail.com> | 2016-07-05 22:36:48 +0200 |
commit | 517e71508ef1d626f0399e6f62e130bb530597cf (patch) | |
tree | ccb8635a78fb8b011bd5517e0343515977eb186b /test/abort | |
parent | c96d701769a8ee39bc90a3b542892b4db9031ab8 (diff) | |
download | node-new-517e71508ef1d626f0399e6f62e130bb530597cf.tar.gz |
test: add abort test for backtrace validation
This commit adds a test that validates backtraces which are
printed on fatal errors.
PR-URL: https://github.com/nodejs/node/pull/6734
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Diffstat (limited to 'test/abort')
-rw-r--r-- | test/abort/test-abort-backtrace.js | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/test/abort/test-abort-backtrace.js b/test/abort/test-abort-backtrace.js new file mode 100644 index 0000000000..7f72ee8e71 --- /dev/null +++ b/test/abort/test-abort-backtrace.js @@ -0,0 +1,24 @@ +'use strict'; +const common = require('../common'); +const assert = require('assert'); +const cp = require('child_process'); + +if (common.isWindows) { + common.skip('Backtraces unimplemented on Windows.'); + return; +} + +if (process.argv[2] === 'child') { + process.abort(); +} else { + const child = cp.spawnSync(`${process.execPath}`, [`${__filename}`, 'child']); + const frames = + child.stderr.toString().trimRight().split('\n').map((s) => s.trim()); + + assert.strictEqual(child.stdout.toString(), ''); + assert.ok(frames.length > 0); + // All frames should start with a frame number. + assert.ok(frames.every((frame, index) => frame.startsWith(`${index + 1}:`))); + // At least some of the frames should include the binary name. + assert.ok(frames.some((frame) => frame.includes(`[${process.execPath}]`))); +} |