我正在尝试使用Jasmine单元测试规范文件测试AngularJS控制器。我的方法是使用$ httpBacked,在以下测试中:
describe('SubmissionsController', function() {
var minimal_mock_response = [ { id: 1 } ];
var scope, routeParams, $httpBackend;
beforeEach(module('submissionServices'));
beforeEach(inject(function($_httpBackend_, $rootScope) {
scope = $rootScope.$new();
$httpBackend = $_httpBackend_;
$httpBackend.expectGET('/submissions').respond(minimal_mock_response);
routeParams = {};
}));
it('passes a trivial test', function() {
expect(true).toBe(true);
});
});
我插入expect(true).toBe(true)只是为了让测试执行并失败,即使它没有触及角度控制器。当我尝试使用jasmine-headless-webkit运行测试时,我收到以下错误:
jasmine-headless-webkit spec/javascripts/SubmissionsControllerSpec.js
Running Jasmine specs...
F
FAIL: 1 test, 1 failure, 0.011 secs.
Submissions controllers SubmissionsController passes a trivial test. (XXX/spec/javascripts/SubmissionsControllerSpec.js:18)
Error: Unknown provider: $_httpBackend_Provider <- $_httpBackend_
Test ordering seed: --seed 9254
是否有任何提示可以纠正此错误并执行简单的测试?
答案 0 :(得分:30)
用下划线括起服务名称有一些好处。
从您的代码中,我可以看到您可能想要保存对$ httpBackend的引用。这就是你想要做的。下划线的位置是一次性的。
beforeEach(inject(function(_$httpBackend_, $rootScope) {
scope = $rootScope.$new();
$httpBackend = _$httpBackend_;
...
Angular足够智能删除下划线并将$ httpBackend返回给您,您可以将其保存到您自己的$ httpBackend。
答案 1 :(得分:1)
我相信这是因为你注入了错误的服务。它不知道$_httpBackend_
是什么。你应该能够做到这一点:
beforeEach(inject(function($httpBackend, $rootScope) {
scope = $rootScope.$new();
$httpBackend.expectGET('/submissions').respond(minimal_mock_response);
routeParams = {};
}));
如果您希望获得对$httpBackend
服务的引用并将其存储为$httpBackend
,那么ghiden's answer即可。