web-dev-qa-db-ja.com

ReferenceError:変数が見つかりません:angularテスト中のモジュール

Angularコントローラーのテストを作成しようとしています。jasminekarmaangular-mocks、ただしエラーが発生し続けるReferenceError: Can't find variable: module

検索 が少しありましたが、angular-mocks私の亭で。

ここで何が欠けているのでしょうか?

以下は私のコードです:

#controller
angular.module('cook_book_ctrl', [])
.controller('cookBookCtrl', function($scope, CookBook, CookBookRecipesService){

  $scope.cookbookoptions = true;

  CookBook.list()
   .success(function(data){
     $scope.recipeList = data;
     CookBookRecipesService.loadCookBookRecipes($scope.recipeList);
   })
   .error(function(error){
   })
  });

#controller test
describe('CookBook controller spec', function(){
  var $httpBackend, $rootScope, createController, authRequestHandler

  beforeEach(module('cook_book_ctrl'));
})

#bower.json
{
  "name": "HelloIonic",
  "private": "true",
  "devDependencies": {
    "ionic": "driftyco/ionic-bower#1.0.0",
    "ionic-service-analytics": "master",
    "ionic-service-core": "~0.1.4",
    "angular-mocks": "1.3.13"
  },
  "dependencies": {
    "ng-cordova-oauth": "~0.1.2",
    "ng-tags-input": "~2.3.0",
    "angular": "~1.4.0",
    "underscore": "~1.8.3",
    "materialize": "~0.97.0"
  },
  "resolutions": {
    "angular": "~1.4.0"
  }
}


   beforeEach(module('cook_book_ctrl'));
})

更新:明確にするためにスクリーンショットを追加

enter image description here

23
sameera207

Bowerを介してangular-mocksをインストールする以外に、以下のように、カルマの設定ファイルにangular-mocks.jsへの参照を追加することを忘れないでください

config.set({

    basePath: '../',
    port: '8000',

    files: [
      'bower_components/angular/angular.js',
      'bower_components/angular-mocks/angular-mocks.js',
      ...
    ]
33
Rebornix

私の場合、karma.conf.jsのファイルパスの順序が間違っていました。

だった:

// list of files / patterns to load in the browser
files: [
  'tests/*.test.js', // this should not be as first!
  'bower_components/angular/angular.min.js',
  'bower_components/angular-mocks/angular-mocks.js',
  'app/*.js',

],

する必要があります:

// list of files / patterns to load in the browser
files: [
  'bower_components/angular/angular.min.js',
  'bower_components/angular-mocks/angular-mocks.js',
  'app/*.js',
  'tests/*.test.js' // now it's cool
],

たぶん明らかなことか、そうでないかもしれませんか? ;-)

11
wit0ld