Angularjs 失败:$httpBackend.whenGET不是函数

Angularjs 失败:$httpBackend.whenGET不是函数,angularjs,protractor,httpbackend,Angularjs,Protractor,Httpbackend,当不是一个函数,但当我输出proxyvar时,我清楚地看到函数在那里 { when: [Function], whenGET: [Function], whenPUT: [Function], whenHEAD: [Function], whenPOST: [Function], whenDELETE: [Function], whenPATCH: [Function], whenJSONP: [Function], context

当不是一个函数,但当我输出
proxy
var时,我清楚地看到函数在那里

{ when: [Function],
    whenGET: [Function],
    whenPUT: [Function],
    whenHEAD: [Function],
    whenPOST: [Function],
    whenDELETE: [Function],
    whenPATCH: [Function],
    whenJSONP: [Function],
    context: {},
  flush: [Function],
      syncContext: [Function],
    onLoad: [Getter] 
}
规格

describe('Login', function () {

    var Injector = require('./helpers/injector');
    var loginPage = require('./pageObjects/LoginPage.js');
    var HttpBackend = require('http-backend-proxy');
    var proxy = new HttpBackend(browser);

    var loginJsonStub,
        loginPost,
        URLbase;
        //projectsJsonStub;

    beforeEach(function () {
        browser.get('http://localhost:9001/#');
        loginPost = {'Login': 'sjv', 'Password': 'password'};

        var injector = new Injector();
        injector.get('loginJson').then(function (result) {
            loginJsonStub = result;
        });

        var injector = new Injector();
        injector.get('URLbase').then(function (result) {
            URLbase = result;
        });
    });

    /*
     Login scenario
     */

    describe('should succeed with correct credentials and proceed to projects page', function () {

        it('should redirect to answerset page immediately if only 1 project', function () {

            loginJsonStub.Response.Payload.User.ProjectAmountIndication = 1;

            proxy.whenGET(URLbase + 'authentication/login', loginPost).respond(200, loginJsonStub);
            //httpBackend.whenGET(URLbase + 'project/getprojectsbyuserhierarchical').respond(200, {}); //projectsJsonStub.one

            loginPage.userName.sendKeys('xx\\svijver');
            loginPage.password.sendKeys('password');
            loginPage.nextButton.click();

            browser.getLocationAbsUrl();
            expect(browser.getCurrentUrl()).toContain('answersets/1');

            browser.sleep(2000);
        });
    });
});
我是否遗漏了/忽略了某些内容?

在模块中,您可以看到它需要一个
ngMockE2E
依赖项(第147行)


对我来说,您的
ngMockE2E
(angular内置模块)不是通过
angular mocks.js
脚本加载的。

对于此行:var HttpBackend=require('http-backend-proxy')

您使用的是大写字母“H”,而您应该使用小写字母“httpBackend”