2015-02-24 5 views
0

код:Каковы причины, по которым этот модульный тест терпит неудачу?

$scope.nextStep = function(route) { 
    session.save($scope.sessionViewModel); 

    var input = { 
     emailAddress : session.account.email, 
     caller : 'USERNAME_EXIST' 
    }; 

    webServiceDal.doesWebLoginExist(input).success(function(response) { 
     console.log(response.WebLoginAppResponse.errorFlag); 
     if ((response.WebLoginAppResponse.errorFlag) && ((response.WebLoginAppResponse.returnCode == 1006) || (response.WebLoginAppResponse.returnCode == 'MSG0307'))) { 
     $scope.globalError = $scope.validationViewModel.email.existErrorMessage; 
     } 
     else 
     $location.path(route); 
    }); 
    }; 

тест:

describe('forgotPasswordCtrl', function() { 

    beforeEach(module('forgotPasswordApp')); 


    var scope, controller, q, $location, route, deferred, mockSessionService, validationProviderMock, webServDalMock; 

    beforeEach(function(){ 

     var config = { 
       urlPath : { 
        match : "" 
       } 
     }; 

     validationProviderMock = { 

     }; 

     var response = { 

     }; 

    mockSessionService = { 
     account : { 
      email : "" 
     }, 
     clear : function(){ 
      return true; 
      } 
    }; 

    webServDalMock = { 
     forgotPassword : function(){ 
      deferred = q.defer(); 
      deferred.resolve(response); 
      return deferred.promise; 
     }, 
     doesWebLoginExist : function(){ 
      deferred = q.defer(); 
      deferred.resolve(response); 
      return deferred.promise; 
     } 
    }; 

    spyOn(webServDalMock, 'forgotPassword').and.callThrough(); 
    spyOn(webServDalMock, 'doesWebLoginExist').and.callThrough(); 
    spyOn(mockSessionService, 'clear').and.callThrough(); 
}); 

     beforeEach(inject(function($rootScope, $controller, _$location_, $q){ 
     scope = $rootScope.$new(); 
     $location = _$location_; 
     q = $q; 
     controller = $controller('forgotPasswordCtrl', { $scope: scope, webServiceDal : webServDalMock, session : mockSessionService, validationProvider : validationProviderMock }); 
     scope.$apply(); 
     })); 


     it('should call clear method of session', function(){ 
      scope.cancel(); 
      expect(mockSessionService.clear).toHaveBeenCalled(); 
     }); 

     it('should return the correct url', function(){ 
      scope.cancel(); 
      config.urlPath.match("tfgm_customer"); 
      expect(window.location.assign).toEqual("/web/tfgm_customer"); 
     }); 

     it('asf', function(){ 
      scope.cancel(); 
      config.urlPath.match("tfgm_customerERROR"); 
      expect(window.location.assign).toEqual("/web/tfgm_admin"); 
     }); 

     it('should call webServiceDal', function(input){ 
      scope.finish(); 
      scope.$apply(); 
      expect(webServDalMock.forgotPassword).toHaveBeenCalled(); 
     }); 

     it('should call webServiceDal', function(){ 
      scope.nextStep(route); 
      scope.$apply(); 
      expect(webServDalMock.doesWebLoginExist).toHaveBeenCalled(); 
     }); 
}); 

перед каждым:

beforeEach(inject(function($rootScope, $controller, _$location_, $q){ 
     scope = $rootScope.$new(); 
     $location = _$location_; 
     q = $q; 
     controller = $controller('forgotPasswordCtrl', { $scope: scope, webServiceDal : webServDalMock, session : mockSessionService, validationProvider : validationProviderMock }); 
     scope.$apply(); 
     })); 

косяк работа за жизнь мне, почему это не проходит? Я вызвал правильную функцию, а так называемый «ожидание». У меня есть другие файлы, на которых я запускал одинаковые тесты, единственное отличие - это именование переменных и т. д., и они проходят. Я пропустил что-то простое?

+2

Что является причиной тест терпит неудачу? –

+0

Просьба указать причину неудачного теста. – Wawy

+0

Является ли тест неудачным из-за того, что ожидания не выполняются, или вы получаете другое сообщение? Кстати, вам не нужно называть $ apply, поскольку вы можете ожидать, что макет будет вызван до запуска дайджеста. Вам понадобится $ apply, чтобы проверить, что вызван обработчик. – thomaux

ответ

1

Вы проблема заключается в том, что отложенное обещание не возвращает success функцию, а скорее (then, catch или finally), $q docs

вам придется изменить свой макет doesWebLoginExist вернуть функцию успеха при вызове.

EDIT: Что-то вроде

doesWebLoginExist : function(){ 
     return {success: function(cb) { 
      cb(response); 
     }}; 
    } 
+0

, так что только там, где он в настоящее время говорит, что возврат отложен. Если вы считаете, что возврат отложен. – RagingBull

+0

@RagingBull проверить мое редактирование. – Wawy

+0

как вы избавились от отсрочки? и почему отложенная работа во всех моих других случаях просто не эта? и что означает cb? но я расскажу о том, что произойдет – RagingBull

Смежные вопросы