Testing sinon存根不工作

Testing sinon存根不工作,testing,mocha.js,sinon,stub,Testing,Mocha.js,Sinon,Stub,我刚刚开始测试,似乎没有成功地完成一个函数的存根。我正在尝试存根到数据库的连接,但它一直在联系它,而不是使用存根的结果: 下面是函数: var self = module.exports = { VerifyAuthentication: function (data){ var deferred = q.defer() if(typeof(data.email)=='undefined'){ deferred.reje

我刚刚开始测试,似乎没有成功地完成一个函数的存根。我正在尝试存根到数据库的连接,但它一直在联系它,而不是使用存根的结果:

下面是函数:

var self = module.exports = {
VerifyAuthentication: function (data){      
    var deferred = q.defer()                
    if(typeof(data.email)=='undefined'){
        deferred.reject({data:{},errorcode:"",errormessage:"param 'email' is mandatory in input object"})
    }else{
        if(typeof(data.password)=='undefined'){
            deferred.reject({data:{},errorcode:"",errormessage:"param 'password' is mandatory in input object"})
        }else{
            var SqlString = "select id, mail, password, origin from tbl_user where mail = ?"    
            var param = [data.email]
            self.ExecuteSingleQuery(SqlString, param).then(function(results){   
                if(results.length > 0)
                {
                    if (results[0].password == data.password)
                    {                   
                        deferred.resolve({data:{"sessionId":results[0].id},errorcode:"",errormessage:""})
                    }else{              
                        deferred.reject({data:{},errorcode:"",errormessage:"bad password"})
                    }
                }else{
                    deferred.reject({data:{},errorcode:"",errormessage:"unknown user"})
                }
            })
        }
    }
    return deferred.promise
},
ExecuteSingleQuery: function (queryString, parameters){     
    var deferred = q.defer()        
    var connection = connect()

    connection.query(queryString, parameters, function (error, results, fields){
        if(error){ deferred.reject(error)};     
        deferred.resolve(results)
    });

    return deferred.promise
},
下面是测试:

var dbconnection = require('../lib/dbConnection.js') 
describe("VerifyAuthentication", function(){
    it("_Returns DbResult object when user name and password match", function(){
        var expectedResult = {data:{"sessionKey":"b12ac0a5-967e-40f3-8c4d-aac0f98328b2"},errorcode:"",errormessage:""}
        stub = sinon.stub(dbconnection, 'ExecuteSingleQuery').returns(Promise.resolve(expectedResult))
        return dbconnection.VerifyAuthentication({email:"correct@adres.com",password:"gtffr"}).then((result)=>{
            expect(result.data.sessionId).to.not.be.undefined
            expect(result.errorcode).to.not.be.undefined
            expect(result.errormessage).to.not.be.undefined
            stub.restore()                
        })
    })  
})

我总是得到一个错误“未知用户”,这是正常的,因为用户确实不在数据库中。但是,我希望存根“ExecuteSingleQuery”函数,避免它连接到DB。

我已经修复了代码中的几个问题,并将更正后的文件发布到下面

dbConnection.js dbConnection.test.js 我在下面概述有问题的部分:

  • expectedResult变量的值类型错误。在 self.ExecuteSingleQuery()您检查长度大于0的数组的实现。存根返回的固定结果是一个对象而不是数组,这就是它返回未知用户异常的原因
  • 数组应该包含一个具有
    {id:'xxx',password:'gtffr'}
    属性的对象。根据
    dbconnection.VerifyAuthentication({email:correct@adres.com,密码:“gtffr”})
    call
  • 最后,我将存根语句改为resolve,而不是return,如图所示
    const stub=sinon.stub(dbconnection,'ExecuteSingleQuery').resolves(expectedResult)-这是解决承诺的首选方法

谢谢,我现在明白我的困惑了。我的预期结果不是“ExecuteSingleQuery”的预期结果,而是VerifyAuthentication的预期结果。我花了一些时间才看到这一点,但多亏了你,我才发现了这一点。感谢您提供有关“resolves”的提示
var self = module.exports = {
    VerifyAuthentication: function (data) {
        var deferred = q.defer();

        if (typeof (data.email) == 'undefined') {
            deferred.reject({
                data: {},
                errorcode: '',
                errormessage: "param 'email' is mandatory in input object"
            });
        } else {
            if (typeof (data.password) == 'undefined') {
                deferred.reject({
                    data: {},
                    errorcode: '',
                    errormessage: "param 'password' is mandatory in input object"
                });
            } else {
                var SqlString = 'select id, mail, password, origin from tbl_user where mail = ?';
                var param = [data.email];

                self.ExecuteSingleQuery(SqlString, param).then(function (results) {
                    if (results.length > 0) {
                        if (results[0].password === data.password) {
                            deferred.resolve({
                                data: {
                                    'sessionId': results[0].id
                                },
                                errorcode: '',
                                errormessage: ''
                            });
                        } else {
                            deferred.reject({
                                data: {},
                                errorcode: '',
                                errormessage: 'bad password'
                            });
                        }
                    } else {
                        deferred.reject({
                            data: {},
                            errorcode: '',
                            errormessage: 'unknown user'
                        });
                    }
                });
            }
        }
        return deferred.promise;
    },
    ExecuteSingleQuery: function (queryString, parameters) {
        var deferred = q.defer();
        var connection = connect();

        connection.query(queryString, parameters, function (error, results, fields) {
            if (error) {
                deferred.reject(error);
            }
            deferred.resolve(results);
        });

        return deferred.promise;
    }
};
describe('VerifyAuthentication', function () {
    it('Returns DbResult object when user name and password match', function () {
        var expectedResult = [{
            id: '123',
            password: 'gtffr'
        }];

        const stub = sinon.stub(dbconnection, 'ExecuteSingleQuery').resolves(expectedResult);

        return dbconnection.VerifyAuthentication({
            email: 'correct@adres.com',
            password: 'gtffr'
        }).then((result) => {
            expect(result.data.sessionId).to.not.be.undefined;
            expect(result.errorcode).to.not.be.undefined;
            expect(result.errormessage).to.not.be.undefined;
            stub.restore();
        });
    });
});