Аргументът „fooController“ не е функция, стана недефиниран

Правя уеб страница и всичко работи чудесно. Няма никакви грешки.

Но сега реших да направя единичен тестов случай с помощта на Karma и Jasmine.

По някакъв начин получавам тази грешка, когато изпълнявам теста си

Error: [ng:areq] Argument 'moduleApp.SearchPageController' is not a function, got undefined

Опитах също само SearchPageController, но получавам същата грешка.

Какво липсва тук??

Route

    angular.module('moduleApp').config(['$routeProvider', function($routeProvider) {

  $routeProvider
    .when('/cmt/complaint/search', {
        templateUrl: 'src/callCenter/page1/searchPage.html',
        controller: 'moduleApp.SearchPageController',
        controllerAs: 'vm'
    })
    .otherwise({ redirectTo: '/' });

}]);

Единичен тест

 describe('Controller: SearchPageController', function () {

 var vm;

 beforeEach(module('moduleApp'));
 beforeEach(inject(function ($controller) {
     vm = $controller('moduleApp.SearchPageController', {}, {});
 }));

 it('should bla bla', function () {

    expect(vm).toBeDefined(); // vm is undefined, probably because of the erro above

 });

});

Контролер

    angular.module('moduleApp.controller').controller('moduleApp.SearchPageController', SearchPageController);
SearchPageController.$inject = ['$log', '$scope', 'moduleApp.SearchPageService', '$http'];


function SearchPageController($log, $scope, searchPageService, $http) {
    'use strict';

    var vm = this;
    vm.filterOption = 'Account ID';

   }

Конфигурация на Karma:

// Karma configuration
m

odule.exports = function(config) {
  config.set({

    // base path that will be used to resolve all patterns (eg. files, exclude)
    basePath: '',


    // frameworks to use
    // available frameworks: https://npmjs.org/browse/keyword/karma-adapter
    frameworks: ['jasmine'],


    // list of files / patterns to load in the browser
    files: [
        'angular.js' // yes this is on the same folder, it works
        '../app/app.js',
        '../components/angular-mocks/angular-mocks.js',
        'unit/*.js',
        '..app/src/'
    ],


    // list of files / patterns to exclude
    exclude: [
    ],


    // preprocess matching files before serving them to the browser
    // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
    preprocessors: {
    },


    // test results reporter to use
    // possible values: 'dots', 'progress'
    // available reporters: https://npmjs.org/browse/keyword/karma-reporter
    reporters: ['progress'],


    // web server port
    port: 9876,


    // enable / disable colors in the output (reporters and logs)
    colors: true,


    // level of logging
    // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
    logLevel: config.LOG_LOG,


    // enable / disable watching file and executing tests whenever any file changes
    autoWatch: true,


    // start these browsers
    // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
    browsers: ['PhantomJS'],


    // Continuous Integration mode
    // if true, Karma captures browsers, runs the tests and exits
    singleRun: false,

    // Concurrency level
    // how many browser should be started simultaneous
    concurrency: Infinity
    })
   }

person user10059050    schedule 10.07.2018    source източник
comment
ако не дори майсторите от StackOverflow могат да ми помогнат, кой може.   -  person user10059050    schedule 10.07.2018


Отговори (1)


Определено не искате да посочите контролера с името на модула:

$routeProvider
.when('/cmt/complaint/search', {
    templateUrl: 'src/callCenter/page1/searchPage.html',
    controller: 'moduleApp.SearchPageController', //<--- this is never correct
    controllerAs: 'vm'
})

Винаги имате достъп до контролер, услуга или фабрика с името, което е дефинирано:

$routeProvider
.when('/cmt/complaint/search', {
    templateUrl: 'src/callCenter/page1/searchPage.html',
    controller: 'SearchPageController',
    controllerAs: 'vm'
})

Изглежда, че включвате тестовете си ПРЕДИ да включите източника на приложението си:

// list of files / patterns to load in the browser
files: [
    'angular.js' // yes this is on the same folder, it works
    '../app/app.js',
    '../components/angular-mocks/angular-mocks.js',
    'unit/*.js',
    '..app/src/' //<-- if this is your app source, it should be before tests!
],

Просто бих пренаредил последните два записа, но също така изглежда, че всъщност не включвате никакви файлове с оператора '..app/src/'. Трябва да използвате wildcarad, за да включите всички .js файлове:

// list of files / patterns to load in the browser
files: [
    'angular.js' // yes this is on the same folder, it works
    '../app/app.js',
    '../components/angular-mocks/angular-mocks.js',
    '..app/src/**/*.js' //<--- all .js files in folders and subfolders
    'unit/*.js',
],

Обикновено искате вашите тестове да са последният запис в секцията с файлове на вашата конфигурация.

person Pop-A-Stash    schedule 10.07.2018