angularjs – 在单元测试中访问已编译的模板

前端之家收集整理的这篇文章主要介绍了angularjs – 在单元测试中访问已编译的模板前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
大多数Angular教程都讨论了使用Protractor进行端到端测试来测试编译模板是否按预期出现.我想知道是否有可能完成单元测试.

大多数关于在单元测试中引用HTML代码的教程都描述了在测试中编译自己编写的代码,例如,以确保正确访问指令:

describe('some function',function () {
  it('should do something',inject(function ($compile,$rootScope) {
    var element = $compile('<div id = "foo" ng-hide = "somecondition">Bar</div>')($Scope);
    $rootScope.digest();
    //Search for a given DOM element and perform some test here
  }));
});@H_301_4@ 
 

但是,假设我想测试实际模板文件中的代码.就像我想测试ng-hide是否成功设置一样.我希望能够做到这样的事情:

describe('some function',function () {
    //Get the div with ID 'foo' in the compiled template
    var elm = $('#foo');
    expect(elm.css('display')).toEqual('none');
  });
});@H_301_4@ 
 

当我这样做时,这不起作用. elm设置为一些HTML / Javascript代码,但不是模板的代码,elm.css(‘display’)返回未定义.

有没有办法用Jasmine / Angular设置单元测试?

使用 ng-html2js将HTML模板加载到Angular的$templateCache中,以便它们在您的测试中可用.

在测试中检索您的特定模板:

var template = $templateCache.get('my/template.html');@H_301_4@ 
 

将模板包装在更容易使用的jqLit​​e / jQuery对象中:

var element = angular.element(template);@H_301_4@ 
 

然后,您可以选择模板中的元素:

var fooEl = element.find('#foo');@H_301_4@ 
 

对于断言,您不想测试该显示:在元素上设置none,即测试ng-hide的内部实现.您可以相信Angular团队有自己的测试,涵盖设置CSS属性.相反,您要测试您是否正确编写了模板,因此更适合测试元素上是否存在ng-hide属性,并且它提供了正确的scope属性以绑定到:

expect(fooEl.attr('ng-hide')).toBe('isFooElHidden');@H_301_4@

猜你在找的Angularjs相关文章