ui-router测试因$ stateChangeStart中的event.preventDefault()失败

时间:2015-04-23 22:05:45

标签: angularjs angular-ui-router karma-jasmine

我的角度测试有问题。

describe('Routes test', function() {
    //Initialize global variables
    var $state,
        $location;

    // Load the main application module
    beforeEach(module("MyApp"));

    beforeEach(inject(function(_$location_, _$state_, $templateCache) {
        $state = _$state_;
        $location = _$location_;

        // We need add the template entry into the templateCache if we ever
        // specify a templateUrl
        $templateCache.put('signin.admin.view.html', 'signin');
    }));

    it('should be redirect to signin if user is not loggedin', function() {
        $rootScope.$apply(function() {
            $location.path('/');
        });
        expect($state.current.name).toEqual('signin');
        console.log($state.current);
    });
});

所以我希望登录状态因为用户没有登录。但是从控制台$ state.current仍然是:

Object{name: '', url: '^', views: null, abstract: true}

要重定向我使用了这段代码:

$rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState, fromParams) {
    if (toState.name.indexOf('signin') === 0 ) {
        if( loggedIn ) {
            event.preventDefault();
            $state.go('layout.dashboard');
        }
    } else {
        if( !loggedIn ) {
            event.preventDefault();
            $state.go('signin');
        }
    }
});

变量loggedIn为false。所以我不明白,当我在浏览器中手动进行测试时,$ state.current正如预期的那样。但不是在这个测试中。

感谢您的帮助。

0 个答案:

没有答案