Mocha和Chai-as-promise超时

时间:2015-02-24 19:54:55

标签: javascript node.js unit-testing mocha chai

这是我认为应该有效的测试。

var chai = require( 'chai' ),
    chaiAsPromised = require( 'chai-as-promised' ),
    assert = require( 'chai' ).assert,
    should = require( 'chai' ).should(),
    saveImage = require( 'helpers/save-image' ),
    Mocha = require( 'mocha' ),
    path = require( 'path' ),
    getUser = require( 'helpers/get-user' )

describe( 'GetUser', function () {

    describe( "getUser( token )", function() {

        it( "should return a user's ID when given token", function() {
            this.timeout( 4000 )

            var token = "LONG-STRING"

            return getUser( token ).should.eventually.include( 'ANOTHER-STRING' )
        })

    })

})

这是函数

var User = require( '../models/userModel' ),
    Q = require( 'q' )

module.exports = function getUser ( token ) {
    return Q.Promise( function ( resolve, reject, notify ) {

        User.findOne( { token: token } ).exec()
        .then( function ( data ) {
            if ( !data )
                reject( new Error( "There was a problem getting the user. No user with that token." ) )

            resolve( data.id )
        }, function ( error ) {
            reject( new Error( error ) )
        })
    })
}

当我在我的应用程序中调用此函数并使用node-theseus调试器时,我看到第8行上的函数触发(.then( function ( data ) { ...)。

但是当我用调试器运行Mocha时,我发现该函数或其他任何函数都没有触发。我只在第4行和第5行看到了一个调用。测试正在使用与我在我的应用程序前端使用的LONG-STRING参数完全相同的token

为什么Mocha和节点如何看待我的应用程序以及如何使此测试工作有所不同?

1 个答案:

答案 0 :(得分:0)

问题是应用程序实际上并未运行,我需要像app = require( '../server.js' )一样启动它。