【问题标题】:How to get console log when the test fails POSTMAN测试失败时如何获取控制台日志 POSTMAN
【发布时间】:2021-11-07 20:04:50
【问题描述】:

这个测试有问题。 当我的 JSON 中的分期付款值低于 100 时(测试 FAIL 时),我想得到一个 consol.log。 但结果,我在测试结果中有一个PASSFAIL,这是可行的,但我无法在consol.log 中获得任何信息。我不知道为什么我的代码不起作用。我以为else if 给了我预期的结果。但还是不行。

var jsonData = JSON.parse(responseBody)

for(var i=0 ; i<=jsonData.length - 1; i++){{

for(var j=0 ; j<=jsonData[i].products.length - 1; j++)

pm.test("Installment > 100", function(){

if (pm.expect(jsonData[i].products[j].installment).to.be.above(100)){}

else if(pm.expect(jsonData[i].products[j].installment).to.be.below(100))
    {console.log(jsonData[i].id)}
    });
}}

【问题讨论】:

    标签: javascript json for-loop testing postman


    【解决方案1】:

    pm.expect 不返回任何东西,它只是抛出一个 Exception (Error) 。所以你不能在需要布尔值的 if 条件下使用它

    尝试以下任何一种:

    var jsonData = JSON.parse(responseBody)
    
    for (var i = 0; i <= jsonData.length - 1; i++) {
        {
    
            for (var j = 0; j <= jsonData[i].products.length - 1; j++)
    
                pm.test("Installment > 100", function () {
                    if (jsonData[i].products[j].installment < 100 && jsonData[i].products[j].installment < 100) console.log(jsonData[i].id)
                    pm.expect(jsonData[i].products[j].installment).to.be.above(100)
                    pm.expect(jsonData[i].products[j].installment).to.be.below(100)
                });
        }
    }
    

    或者:

    var jsonData = JSON.parse(responseBody)
    
    for (var i = 0; i <= jsonData.length - 1; i++) {
        {
    
            for (var j = 0; j <= jsonData[i].products.length - 1; j++)
    
                pm.test("Installment > 100", function () {
    
                    try {
                        pm.expect(jsonData[i].products[j].installment).to.be.above(100)
                    } catch (e) {
                        pm.expect(jsonData[i].products[j].installment).to.be.below(100)
                        console.log(jsonData[i].id)
                    }
    
                })
        }
    }
    

    【讨论】:

    • 非常感谢,现在我对 pm.expect 的工作原理有了更好的了解。显示测试错误时是否无法获取日志?
    • 我不确定您要做什么,我可以通过控制台 log(e) 查看抛出的错误
    • 我的主要目标是在发生错误时在 json 中进行本地化
    猜你喜欢
    • 2018-10-28
    • 2017-05-19
    • 2017-03-05
    • 1970-01-01
    • 2013-09-16
    • 1970-01-01
    • 2017-11-22
    • 2021-09-24
    • 1970-01-01
    相关资源
    最近更新 更多