【问题标题】:How to inject angular value and angular constant into karma unit test?如何将角度值和角度常数注入业力单元测试?
【发布时间】:2015-04-10 13:28:19
【问题描述】:

我想测试这个控制器

/controllers/datetimepicker.js

angular.module('c2gyoApp')
  .value('smConfig', {
    rate: 'A',
    tariff: 'classic'
  })
  .controller('DatetimepickerCtrl', [
    '$scope',
    'stadtmobilRates',
    'smConfig',
    function($scope, stadtmobilRates, smConfig) {
      ...
      $scope.getCurrentRate = function(rate, tariff) {
        // studi and classic have the same rates
        if (tariff === 'studi') {
          tariff = 'classic';
        }
        return stadtmobilRates[tariff][rate];
      };
      ...
    }
  ]);

自从我编写测试以来,我已经更改了控制器。一些常量已移至angular.module('c2gyoApp').value('smConfig'){},我还需要来自angular.module('c2gyoApp').constant('stadtmobilRates'){} 的常量:

/services/stadtmobilrates.js

angular.module('c2gyoApp')
  .constant('stadtmobilRates', {
    'classic': {
      'A': {
        'night': 0,
        'hour': 1.4,
        'day': 21,
        'week': 125,
        'km000': 0.2,
        'km101': 0.18,
        'km701': 0.18
      },
      ...
});

这是我目前的测试:

/test/spec/controllers/datetimepicker.js

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

  // load the controller's module
  beforeEach(module('c2gyoApp'));

  var DatetimepickerCtrl;
  var scope;

  // Initialize the controller and a mock scope
  beforeEach(inject(function($controller, $rootScope) {
    scope = $rootScope.$new();
    DatetimepickerCtrl = $controller('DatetimepickerCtrl', {
      $scope: scope
    });
  }));

  it('should calculate the correct price', function() {
    expect(scope.price(10, 10, 0, 0, 'A', 'basic')
      .toFixed(2)).toEqual((18.20).toFixed(2));
      ...
  });
});

如何将angular.module('c2gyoApp').value('smConfig'){}angular.module('c2gyoApp').constant('stadtmobilRates'){} 注入到测试中?我正在使用标准的约曼布局。 karma.conf 文件包含所有必要的 .js 文件,因此只是在哪里注入 angular 元素的问题。

【问题讨论】:

    标签: javascript angularjs unit-testing karma-runner yeoman


    【解决方案1】:

    由于您要添加 c2gyoApp 模块:

    beforeEach(module('c2gyoApp'));
    

    在该模块中注册的所有内容都应该是可注入的。所以,这应该工作:

    var smConfig, stadtmobilRates;
    
    beforeEach(inject(function($controller, $rootScope, _smConfig_, _stadtmobilRates_) {
    
       scope = $rootScope.$new();
       DatetimepickerCtrl = $controller('DatetimepickerCtrl', {
          $scope: scope
       });
       smConfig = _smConfig_;
       stadtmobilRates = _stadtmobilRates_;
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-04-25
      • 2014-11-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-11-02
      • 2021-05-25
      • 1970-01-01
      相关资源
      最近更新 更多