使用angular-mocks/jasmine进行测试服务 - 类型错误:未定义的对象

13

我正在尝试在我的Angular应用程序中使用jasmine/karma/phantomJS测试一个简单的服务。

jasmine版本:2.4.1 angular/angular-mocks版本:1.5.7 phantomJS版本:2.1.1

QueryParameters.service.tests.js:(QueryParameters.service.js是app.service模块的一部分,实际上是一个工厂而不是服务)

describe('myApp.QueryParametersService', function() {

  var QueryParametersService;

  beforeEach(module('myApp'));
  beforeEach(module('app.service'));
  beforeEach(inject(function ($injector) {
    QueryParametersService = $injector.get('QueryParametersService');
  }));

  var testObject = {
    name : 'Hans',
    age  : '27'
  };

  it('Should output correct querystrings', function() {
    expect(QueryParametersService.toQueryParams(testObject)).toBe('?name=Hans&age=27');
  });

});

QueryParametersService.js:

(function() {
  'use strict';

  angular.module('app.service')
    .factory('QueryParametersService', QueryParametersService);

  QueryParametersService.$inject = [];

  function QueryParametersService() {

    var service = {
      toQueryParams : toQueryParams
    };

    return service;

    function toQueryParams(queryObject) {
      <removed code here>
    }
  }
})();

在Gruntfile.js文件中:

karma: {
      unit: {
        options: {
          frameworks: ['jasmine'],
          singleRun: true,
          browsers: ['PhantomJS'],
          files: [
            '<%= yeoman.client %>/bower_components/angular/angular.js',
            '<%= yeoman.client %>/bower_components/angular-mocks/angular-mocks.js',
            '<%= yeoman.client %>/app/app.js',
            '<%= yeoman.client %>/app/filters/filter.module.js',
            '<%= yeoman.client %>/app/directives/directive.module.js',
            '<%= yeoman.client %>/app/services/service.module.js',
            '<%= yeoman.client %>/app/services/tests/*.js'
          ]
        }
      }
    }

我的主模块(在 app.js 中)声明如下:

  angular.module('myApp', [
    'angular-thumbnails',
    'angularUtils.directives.dirPagination',
    'app.directive',
    'app.filter',
    'app.service',
    'color.picker',
    'ngCookies',
    'ngFileUpload',
    'ngImgCrop',
    'ngMaterial',
    'ngMessages',
    'ngResource',
    'ngSanitize',
    'ui.router',
    'validation.match',
  ])

运行测试时我收到的错误信息:

PhantomJS 2.1.1 (Mac OS X 0.0.0) myApp.QueryParametersService Should output correct querystrings FAILED
        /<filepath>/client/bower_components/angular/angular.js:4632:53
        forEach@/<filepath>/client/bower_components/angular/angular.js:321:24
        loadModules@/<filepath>/client/bower_components/angular/angular.js:4592:12
        createInjector@/<filepath>/client/bower_components/angular/angular.js:4514:30
        workFn@/<filepath>/client/bower_components/angular-mocks/angular-mocks.js:3067:60
        TypeError: undefined is not an object (evaluating 'QueryParametersService.toQueryParams') in /<filepath>/client/app/services/tests/query-parameters.service.tests.js (line 65)
        /<filepath>/client/app/services/tests/query-parameters.service.tests.js:65:34
PhantomJS 2.1.1 (Mac OS X 0.0.0): Executed 1 of 1 (1 FAILED) ERROR (0.002 secs / 0.009 secs)

我在这里做错了什么?


1
似乎 karma.conf.js 文件中没有包含 QueryParametersService.js? - jimmygchen
这里包含了: '<%= yeoman.client %>/app/services/service.module.js', - Hans Petter Naumann
实际上,@jchen86,你是正确的。我以为包含整个服务模块就足够了,但特别包括了服务部分解决了我的问题。 - Hans Petter Naumann
1个回答

2
正如 @jchen86 指出的那样,QueryParametersService.js 没有被包含在配置中(我认为当我包含整个服务模块时它会被包含)。通过更改 gruntfile 以包含服务文件夹中的所有 js 文件来解决问题:
'<%= yeoman.client %>/app/services/*.js'

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接