单元测试 – 如何在茉莉花中测试角度控制器的本地变量

前端之家收集整理的这篇文章主要介绍了单元测试 – 如何在茉莉花中测试角度控制器的本地变量前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个带有局部变量的控制器
function IndexCtrl($scope) {
  var pagesById = [];
  loadPages();

  // snip

  function loadPages() {
    // pagesById gets populated
  }

  // snip
}

我想测试pageById是否正确填充,但我不知道如何从我的()获取它.我不需要这个变量在$范围内,它只是一个中间的信息集,所以如果我可以避免将它添加到$scope,这将是理想的.

it('scope.pages should populated based on pages data.',function() {
    $httpBackend.flush();
    expect(pagesById).toEqualData(mock_page_results);
});

给我

ReferenceError: pagesById is not defined

除了将其附加到$范围外,我还有其他选项吗?

在你的茉莉花规格中,先创建控制器:
var ctrl;

beforeEach(inject(function($rootScope,$controller) {
  scope = $rootScope.$new();
  ctrl = $controller('myController',{
     $scope: scope
  });
}));

然后您可以通过执行ctrl.pagesById访问其属性.当然,而不是做var pagesById,你需要在你的控制器中使用this.pagesById.

猜你在找的Angularjs相关文章