单元测试 – Jasmine用templateUrl测试AngularJS指令

前端之家收集整理的这篇文章主要介绍了单元测试 – Jasmine用templateUrl测试AngularJS指令前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用Jasmine编写AngularJS的指令测试,并使用templateUrl: https://gist.github.com/tanepiper/62bd10125e8408def5cc

但是,当我运行测试,我得到错误包括提示

Error: Unexpected request: GET views/currency-select.html

从我在文档中读到的,我认为我做的正确,但它似乎不是 – 我在这里缺少什么?

谢谢

当您使用ngMockE2E或ngMock时,将使用您指定的规则在本地处理所有HTTP请求,并且不会将任何HTTP请求传递到服务器。由于模板是通过HTTP请求的,它们也在本地进行处理。因为你的应用程序尝试连接到views / currency-select.html时没有指定任何操作,它告诉你它不知道如何处理它。您可以轻松地告诉ngMockE2E传递您的模板请求:
$httpBackend.whenGET('views/currency-select.html').passThrough();

请记住,如果愿意,您还可以在路由路径中使用正则表达式来传递所有模板。

文档详细讨论了这一点:http://docs.angularjs.org/api/ngMockE2E.$httpBackend

更新

FYI,您需要使用$ injector访问新的后端。从链接的文档:

var $httpBackend;
beforeEach(inject(function($injector) {
  $httpBackend = $injector.get('$httpBackend');
  $httpBackend.whenGET('views/currency-select.html').respond(200,'');
}));

猜你在找的Angularjs相关文章