nodejs + qunit:在测试中保存返回的异常

时间:2015-01-17 13:15:38

标签: javascript node.js qunit

我是新来的(一天)并且还在学习..

我想从异常中保存消息和堆栈跟踪。我不知道该怎么做。

在下面的代码中,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
);

});

2 个答案:

答案 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);
});