2016-09-15 4 views
0

Я пытаюсь понять плагин grunt-karma и jasmine framework, чтобы написать первый тест кармы. когда я запускаю тест на карму (тест grunt), я вижу ошибку для инициализации модуля, области. Что я делаю не так ? Спасибо за вашу помощь.Ошибка Karma на AngularJS Test

gruntfile.js

karma: { 
     unit: { 
      configFile: 'karma.conf.js' 
     } 
     } 

grunt.registerTask('test',['karma:unit']); 

karma.conf.js

files: [ 
    'scripts/bower_components/angular/angular.js', 
    'scripts/bower_components/angular-mocks/angular-mocks.js', 
    'config/config.js', 
    'scripts/app.js', 
    'scripts/controllers/*.js', 
    'test/unittest/personController.test.js' 
], 

app.js

var app = angular.module('myApp', ['services.config']); 

personController.js

app.controller('personCtrl', ['$scope', function($scope) { 
    $scope.firstName = "John"; 
    $scope.lastName = "Doe"; 
    $scope.fullName = function() { 
     return $scope.firstName + " " + $scope.lastName; 
    }; 
}]); 

config.js (service.config)

'use strict'; 

angular.module('services.config', []) 
    .constant('configuration', { 
    getAllBooks: '@@getAllBooks' 
}); 

personController.test.js

describe('Testing AngularJS SampleApp [app]', function(){ 

    //myApp will be loaded once instead of mentioning in every it() function 
    beforeEach(module('myApp')); 

    describe('1.Testing SampleApp Controllers', function(){ 

     var scope; 
     var ctrl; 

     //loading controller once inside describe instead of every it() function 
     beforeEach(inject(function($controller,$rootScope){ 
       scope = $rootScope.$new(); 
       ctrl = $controller('personCtrl',{$scope:scope}); 
      })); 

     afterEach(function(){ 
      //clean-up code 
     }); 

     it('should initialize the scope', function(){ 
      expect(scope.firstName).toBeDefined('John'); 
      expect(scope.lastName).toBeDefined('Doe'); 
     }); 

    }); 
}); 

ОШИБКА:

15 09 2016 17:08:37.568:INFO [Chrome 52.0.2743 (Mac OS X 10.10.5)]: Connected on socket /#Pq9aUWSZ6FSyQjeRAAAA with id 50553444 
Chrome 52.0.2743 (Mac OS X 10.10.5) Testing AngularJS SampleApp [app] 1.Testing SampleApp Controllers should initialize the scope FAILED 
    Error: [$injector:modulerr] Failed to instantiate module services.config due to: 
    Error: [ng:areq] Argument 'fn' is not a function, got string 
    http://errors.angularjs.org/1.4.8/ng/areq?p0=fn&p1=not%20a%20function%2C%20got%20string 
     at scripts/bower_components/angular/angular.js:68:12 

и

at Object.workFn (scripts/bower_components/angular-mocks/angular-mocks.js:3074:52) 
    TypeError: Cannot read property 'firstName' of undefined 
     at Object.<anonymous> (test/unittest/personController.test.js:23:16) 
Chrome 52.0.2743 (Mac OS X 10.10.5): Executed 1 of 1 (1 FAILED) ERROR (0.034 secs/0.02 secs) 

Вопросы:
1. Каков наилучший способ обратиться к karma.con.js из файла grunt file.js? Я прочитал в некоторых блогах, что мы также можем переопределить все свойства karma.conf.js в файле grunt вместо обращения к файлу?
2. Каков наилучший способ доступа к области контроллера в файлах xxx.test.js?

+0

Ошибка в модуле services.config, ошибка явно указывает это. Пожалуйста, предоставьте исходный код для модуля services.config – estus

+0

@estus: спасибо за ваше время. Я отредактировал вопрос с файлом config.js, который определяет service.config. Код работает отлично и не видел никаких ошибок. Но тестирование терпит неудачу. –

ответ

0

Я смог устранить проблему, спасибо estus за указание проблемы, и я должен был осознать.

personController.test.js

beforeEach(module('services.config')); 
beforeEach(module('myApp')); 

Я не сработал services.config модуль, который используется в myApp. а затем я получил ошибку для TypeError: angular.element.cleanData не является функцией. Я должен был убедиться, что версии angular и angular-mocks - это то же самое.

Постное
1.load всех зависимых модулей, прежде чем загрузка приложения
2.Add angualr, angualr-издевается, а также ссылки на все файлы сценарии, чтобы
3.Make обязательно установить совместимую угловые и версия угловых маков

Смежные вопросы