返回承诺的 Jasmine 单元测试角度服务无法解决



给定此测试代码

it('can login', inject(function ($httpBackend,$rootScope) {
        // Set up the mock http service responses
        authRequestHandler = $httpBackend.when('POST', '/login')
            .respond({success: true, user: {email: 'david@blah.com', roles: ['user']}});
        var promise = dsAuth.authenticateUser('123', '123')
        promise.then(function (success) {
            console.log('Got login response');
            expect(success).toBe(true);
            expect(dsIdentity.isAuthenticated()).toBe(true);
            console.log(dsIdentity.currentUser);
        });
        $rootScope.$digest(); //a solution found in on SO that doesn't work
    }));

该承诺(从身份验证服务返回)永远不会解决?如何解决这个问题? .then() 函数中的代码永远不会被调用

服务代码 :

(function(angular) {
angular.module('dsApp').factory('dsAuth',
    ['$http','$q',dsAuth]);
function dsAuth($http,$q) {
    return {
        authenticateUser: function(username,password) {
            var dfd = $q.defer();
            $http.post('/login', {username: username, password: password}).then(function (resp) {
                console.log($resp);
                if (resp.data.success) {
                    var user = new atUser();
                    angular.extend(user, resp.data.user);
                    atIdentity.currentUser = user;
                    dfd.resolve(true);
                } else {
                    dfd.resolve(false);
                }
            });
            return dfd.promise;
        },
        logoutUser: function() {
            var dfd = $q.defer();
            $http.post('/logout', {logout: true}).then(function () {
                atIdentity.currentUser = undefined;
                dfd.resolve();
            });
            return dfd.promise;
        }
    };
}

})(this.angular);

Jasmine不适用于异步期望。对此的解决方案是使用 httpBackendflush()函数

it('can login', inject(function ($httpBackend,$rootScope) {
        // Set up the mock http service responses
        authRequestHandler = $httpBackend.when('POST', '/login')
            .respond({success: true, user: {email: 'david@blah.com', roles: ['user']}});
        var promise = dsAuth.authenticateUser('123', '123')
        var success = false;
        promise.then(function (result) {
            console.log('Got login response');
            success = result;
            console.log(dsIdentity.currentUser);
        });
        $httpBackend.flush();
        expect(success).toBe(true);
        expect(dsIdentity.isAuthenticated()).toBe(true);
    }));

我不太确定dsIdentity来自哪里,但我认为您可以在自己的代码中弄清楚。模式是相同的 - 在闭包外部创建一个变量,然后在闭包内设置值。flush()会导致承诺被解雇,然后你就可以走了。

最新更新