首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >$httpBackend模拟不返回响应

$httpBackend模拟不返回响应
EN

Stack Overflow用户
提问于 2016-11-15 17:54:57
回答 1查看 354关注 0票数 0

我模拟了一个httpBackend来测试以下代码。

代码语言:javascript
复制
  self.Api.post('/endpoint/action/', actionData)
    .then(function(resp){
      result = _.get(resp, 'data.MessageList');
      if(resp.status = 200 && result) {
        for (var i = 0; i < result.length; i++) {
          addResultMessage(result[i]);
        }
      }
    });

我模仿了我的服务,如下所示:

代码语言:javascript
复制
  beforeEach(function(){
      angular.mock.module(function(ApiProvider) {
        ApiProvider.setUrl('http://localhost:10010');
      });
  });

  beforeEach(inject(function($rootScope, $controller, _$interval_,  $q, $injector, $httpBackend){
    $rootScope = $injector.get('$rootScope');
    scope = $rootScope;
    httpBackend = $httpBackend;

    createController = function() {
      return $controller('MyCtrl',{
        $scope: scope,
        $uibModalInstance: modalInstance,
        $interval: _$interval_,
      });
    }
  }));

在一个it中

代码语言:javascript
复制
       httpBackend
        .when('POST', 'http://localhost:10010/endpoint/action/')
          .respond(200, mockedResponse);

当我将POST发送到该端点时,我没有得到任何响应。我没有得到任何错误,只是我没有得到任何响应回调

EN

回答 1

Stack Overflow用户

发布于 2016-11-15 18:39:28

您应该在测试之后调用flush(),如下所示:

代码语言:javascript
复制
it('should read expired login data', inject(function(authSrvc) {
    $httpBackend.expectGET('data/auth.json').respond(200, mockedResponse);

    authSrvc.checkStatus().then(function(data){
      expect(authSrvc.isValidSession()).toEqual(false);
    });

    $httpBackend.flush();
  }));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40606790

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档