我是新来的(一天)并且还在学习..
我想从异常中保存消息和堆栈跟踪。我不知道该怎么做。
在下面的代码中,stacktrace和message的副本是变量中的位置。我假设范围不同。
QUnit.test("Internal scheme validator - destination list - empty - no strict", function(assert) {
var path ='[{"sid":"test_scheme0","ssch":"","dstli":""}]';
var pathi = JSON.parse(path);
var expected = 'undefined scheme destination list';
var err;
var enm;
var emsg;
var estk;
assert.throws(
function(){
"use strict";
sysCatalog.__vschi__(pathi,"SchemeTest Ignore Message" );
},
function(e){
err= JSON.parse(JSON.stringify(e));
enm= JSON.parse(JSON.stringify(e.name));
emsg = JSON.parse(JSON.stringify(e.message));
estk = JSON.parse(JSON.stringify(e.stack));
return emsg === expected;
},
'Wrong exception message returned.\nExpected: '+ expected+'\nActual: '+ emsg +'\nBacktrace:\n'+estk
);
});
答案 0 :(得分:0)
这取决于您希望如何保存结果。如果要将错误和堆栈跟踪输出到文件,则可以使用节点中的fs api将结果保存到格式良好的文件中。
fs.writeFile(...);
此外,还有一个与qunit and node集成的模块,可以将结果输出到XML文件。
答案 1 :(得分:0)
需要花一点时间重新思考.. quinit异常机制对我的需求来说有点简陋。这是我恢复的解决方案,这是在转移到qunit之前开始的测试代码。
有一个缺点,qunit会在以下情况下转储回溯:
QUnit.config.notrycatch = true;
QUnit.test("Internal scheme validator - destination list - empty - strict", function(assert) {
var path ='[{"sid":"test_scheme0","ssch":"","dstli":""}]';
var pathi = JSON.parse(path);
var expected = 'zero length scheme destination list';
var enm;
var emsg;
var estk;
try{
sysCatalog.__vschi__(pathi,"SchemeTest Ignore Message",true );
}catch(e){
// here the test failed and we should not proceed
//cc=false;
enm= e.name;
emsg = e.message;
estk = e.stack;
}
assert.strictEqual(emsg,expected, 'Wrong exception message returned.\nBacktrace:\n'+estk);
});