簡體   English   中英

Angular mock無法注入我的模塊依賴項

[英]Angular mock fails to inject my module dependencies

我想為我的應用程序fooApp測試一個Angular控制器,定義如下:

var fooApp = angular.module('fooApp', [ 'ngRoute', 'ngAnimate', 'hmTouchEvents' ]);
...

控制器MainCtrl定義如下:

"use strict";

fooApp.controller('MainCtrl', function ($scope, $rootScope, fooService) {
    ...
}

所以我已經測試了幾種創建測試的方法,比如這個:

'use strict';

describe('MainController test', function () {

    var scope;
    var controller;

    beforeEach(function () {
            angular.mock.module('ngRoute', []);
            angular.mock.module('ngAnimate', []);
            angular.mock.module('hmTouchEvents', []);
            angular.module('cwfApp', [ 'ngRoute', 'ngAnimate', 'hmTouchEvents' ]);

            angular.mock.inject(function ($rootScope, $controller) {
                scope = $rootScope.$new();
                controller = $controller('MainCtrl', {
                    $scope: scope
                });
            });
        });

        it('should display a list', function () {
            console.log('-------------- Run Test 1 | ' + scope);
            expect(scope.currentStep).toBe(1);
        });

});

結果:

        Error: [$injector:modulerr] http://errors.angularjs.org/1.2.16-build.64+sha.245de33/$injector/modulerr?p0=undefined&p1=Error%3A%20%5Bng%3Aareq%5D%20http%3A%2F%2Ferrors.angularjs.org%2F1.2.16-build.64%2Bsha.245de33%2Fng%2Fareq%3Fp0%3Dfn%26p1%3Dnot%2520a%2520function%252C%2520got%2520undefined%0A%20%20%20%20at%20Error%20(%3Canonymous%3E)%0A%20%20%20%20at%20http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A6%3A471%0A%20%20%20%20at%20wb%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A18%3A360)%0A%20%20%20%20at%20Qa%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A18%3A447)%0A%20%20%20%20at%20nc%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A31%3A191)%0A%20%20%20%20at%20Object.d%20%5Bas%20invoke%5D%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A33%3A176)%0A%20%20%20%20at%20http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A32%3A254%0A%20%20%20%20at%20Array.forEach%20(native)%0A%20%20%20%20at%20r%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A7%3A298)%0A%20%20%20%20at%20e%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A32%3A9)
        at Error (<anonymous>)
        at d:/dev/foo/app/bower_components/angular/angular.min.js:6:471
        at d:/dev/foo/app/bower_components/angular/angular.min.js:32:400
        at Array.forEach (native)
        at r (d:/dev/foo/app/bower_components/angular/angular.min.js:7:298)
        at e (d:/dev/foo/app/bower_components/angular/angular.min.js:32:9)
        at Object.$b [as injector] (d:/dev/foo/app/bower_components/angular/angular.min.js:35:98)
        at workFn (d:/dev/foo/app/bower_components/angular-mocks/angular-mocks.js:2142:52)
        at Object.window.inject.angular.mock.inject [as inject] (d:/dev/foo/app/bower_components/angular-mocks/angular-mocks.js:2133:37)
        at null.<anonymous> (d:/dev/foo/test/jasmine/todo.test.js:15:22)
    TypeError: Cannot read property 'currentStep' of undefined
        at null.<anonymous> (d:/dev/foo/test/jasmine/todo.test.js:25:21)
Chrome 31.0.1650 (Windows 7): Executed 1 of 1 (1 FAILED) ERROR (0.023 secs / 0.015 secs)        

我還測試過beforeEach(angular.mock.module('cwfApp')); (而不是前一代碼中的第一個beforeEach ),但錯誤幾乎相同。

關於我的karma.conf.js文件,我設置了這個文件列表:

    files: [
        'app/bower_components/angular/angular.min.js',
        'app/bower_components/angular-route/angular-route.min.js',
        'app/bower_components/hammerjs/hammer.min.js',
        'app/bower_components/angular-hammer/angular-hammer.js',
        'app/bower_components/angular-mocks/angular-mocks.js',

        'app/js/foo-application.js',
        'app/js/foo-controllers.js',
        'app/js/foo-services.js',
        'app/js/foo-router.js',

        'test/jasmine/*.js'
    ],

注入似乎失敗了,但我真的不明白我的配置中缺少什么或錯誤。 上面的堆棧跟蹤沒有給出很多解釋......

任何想法?

我正在使用Angular 1.2.8。

問候

使用@Engineer提供的代碼進行編輯:

beforeEach(angular.mock.module('fooApp'));

beforeEach(angular.mock.inject(function($rootScope, $controller) {
    scope = $rootScope.$new();
    controller = $controller('MainCtrl', {
        $scope: scope
    });
}));

it('should display a list', function () {
    console.log('-------------- Run Test 1 | ' + scope);
    expect(scope.currentStep).toBe(1);
});

錯誤幾乎相同:

    Error: [$injector:modulerr] http://errors.angularjs.org/1.2.16-build.64+sha.245de33/$injector/modulerr?p0=cwfApp&p1=Error%3A%20%5B%24injector%3Amodulerr%5D%20http%3A%2F%2Ferrors.angularjs.org%2F1.2.16-build.64%2Bsha.245de33%2F%24injector%2Fmodulerr%3Fp0%3DngAnimate%26p1%3DError%253A%2520%255B%2524injector%253Anomod%255D%2520http%253A%252F%252Ferrors.angularjs.org%252F1.2.16-build.64%252Bsha.245de33%252F%2524injector%252Fnomod%253Fp0%253DngAnimate%250A%2520%2520%2520%2520at%2520Error%2520(%253Canonymous%253E)%250A%2520%2520%2520%2520at%2520http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A6%253A471%250A%2520%2520%2520%2520at%2520http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A20%253A260%250A%2520%2520%2520%2520at%2520http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A21%253A262%250A%2520%2520%2520%2520at%2520http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A32%253A69%250A%2520%2520%2520%2520at%2520Array.forEach%2520(native)%250A%2520%2520%2520%2520at%2520r%2520(http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A7%253A298)%250A%2520%2520%2520%2520at%2520e%2520(http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A32%253A9)%250A%2520%2520%2520%2520at%2520http%253A%252F%252Flocalhost%253A9876%252Fbase%252Fapp%252Fbower_components%252Fangular%252Fangular.min.js%253F5961971009303638e9ad386869316e8c83f67e56%253A32%253A86%250A%2520%2520%2520%2520at%2520Array.forEach%2520(native)%0A%20%20%20%20at%20Error%20(%3Canonymous%3E)%0A%20%20%20%20at%20http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A6%3A471%0A%20%20%20%20at%20http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A32%3A400%0A%20%20%20%20at%20Array.forEach%20(native)%0A%20%20%20%20at%20r%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A7%3A298)%0A%20%20%20%20at%20e%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A32%3A9)%0A%20%20%20%20at%20http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A32%3A86%0A%20%20%20%20at%20Array.forEach%20(native)%0A%20%20%20%20at%20r%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A7%3A298)%0A%20%20%20%20at%20e%20(http%3A%2F%2Flocalhost%3A9876%2Fbase%2Fapp%2Fbower_components%2Fangular%2Fangular.min.js%3F5961971009303638e9ad386869316e8c83f67e56%3A32%3A9)
        at Error (<anonymous>)
        at d:/dev/foo/app/bower_components/angular/angular.min.js:6:471
        at d:/dev/foo/app/bower_components/angular/angular.min.js:32:400
        at Array.forEach (native)
        at r (d:/dev/foo/app/bower_components/angular/angular.min.js:7:298)
        at e (d:/dev/foo/app/bower_components/angular/angular.min.js:32:9)
        at Object.$b [as injector] (d:/dev/foo/app/bower_components/angular/angular.min.js:35:98)
        at workFn (d:/dev/foo/app/bower_components/angular-mocks/angular-mocks.js:2142:52)
    TypeError: Cannot read property 'currentStep' of undefined
        at null.<anonymous> (d:/dev/foo/test/jasmine/todo.test.js:20:21)

我會嘗試創造一個小提琴來重現我的問題......

我的問題實際上是由於karma.conf.js一個小錯誤。 實際上,我的應用程序定義如下:

var fooApp = angular.module('fooApp', [ 'ngRoute', 'ngAnimate', 'hmTouchEvents' ]);

我的karma.conf.js加載以下腳本:

files: [
    'app/bower_components/angular/angular.min.js',
    'app/bower_components/angular-route/angular-route.min.js',
    'app/bower_components/hammerjs/hammer.min.js',
    'app/bower_components/angular-hammer/angular-hammer.js',
    'app/bower_components/angular-mocks/angular-mocks.js',

    'app/js/foo-application.js',
    'app/js/foo-controllers.js',
    'app/js/foo-services.js',
    'app/js/foo-router.js',

    'test/jasmine/*.js'
], ...

但是沒有加載模塊ngAnimate 所以我剛添加了這一行:

    'app/bower_components/angular-animate/angular-animate.min.js',

它的工作原理!

您正在測試中重新定義fooApp模塊。

您需要在測試代碼中使用Angular加載它,如下所示:

angular.mock.module('ngRoute', 'ngAnimate', 'hmTouchEvents', 'fooApp');

試試這樣:

describe('MainController test', function () {
    var scope;
    var controller;

    beforeEach(angular.mock.module('fooApp'));
    beforeEach(angular.mock.inject(function($rootScope, $controller) {
        scope = $rootScope.$new();
        controller = $controller('MainCtrl', {
            $scope: scope
        });
    });
    it('should display a list', function () {
        console.log('-------------- Run Test 1 | ' + scope);
        expect(scope.currentStep).toBe(1);
    });
});

您需要了解的是,當您注入模塊時,如果您聲明某個模塊及其依賴項(如angular.module('fooApp', [ 'ngRoute', 'ngAnimate', 'hmTouchEvents' ]) )( fooApp )在測試中,您不需要注入依賴模塊。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM