测试函数将引发UnhandledPromiseRejectionWarning。导致测试不通过

时间:2018-10-24 20:21:16

标签: javascript node.js testing promise mocha

我玩过Mocha Testing。 我注意到我的函数在少数地方抛出了“ UnhandledPromiseRejectionWarning” 的Warring。它使脚本不通过检查。

我在互联网上找不到有用的例子来教授/显示解决该问题的好方法。也许你们其中之一可以提供帮助。

如果您对我的代码有任何其他评论,请随时分享。我在这里学习:)

发生问题的功能。

it('/POST /logout => Logout a user by purging a session', (done) => {
        let loginInfo = {};
        loginInfo.usr = 'testuser';
        loginInfo.psw = 'mochatesting197';
        let agent = chai.request.agent(app);
        let json = {};
        json.logout = true;
        agent.post('/login')
            .send(loginInfo)
            .then((res) => {
                return agent.post('/logout')
                    .send(json)
                    .then((res) => {
                        res.should.have.status(200);
                        res.body.should.be.a('object');
                        res.body['success'].should.have.property('message').eql('YOU HAVE LOGGED OUT');
                        done();
                    }).catch(function (err) {
                        throw err;
                    });
            });
    });

1 个答案:

答案 0 :(得分:1)

当Promise被拒绝但没有关联的catch处理程序时,发生UnhandledPromiseRejectionWarning。由于处理程序可以随时(即使在被拒绝之后)也可以附加到Promise,因此默认行为是在许多事件循环结束后将警告记录到默认值(控制台)。

在您提供的代码中,最可能的原因是您的catch块放置在错误的位置。尝试将捕获处理程序移到Promise链的底部。

这肯定不能解决问题,但是它在您提供的代码中最有可能出现。另外,请注意,在使用Mocha的“完成”回调机制时,请勿抛出异常。相反,您应该在调用完成时出现错误(也如下所示)

it('/POST /logout => Logout a user by purging a session', (done) => {
    let loginInfo = {};
    loginInfo.usr = 'testuser';
    loginInfo.psw = 'mochatesting197';
    let agent = chai.request.agent(app);
    let json = {};
    json.logout = true;
    agent.post('/login')
        .send(loginInfo)
        .then((res) => {
            return agent.post('/logout')
                .send(json)
                .then((res) => {
                    res.should.have.status(200);
                    res.body.should.be.a('object');
                    res.body['success'].should.have.property('message').eql('YOU HAVE LOGGED OUT');
                    done();
                })
        })
        .catch(function (err) {
            done(err);
        });
});