如何检查方法是否被称为茉莉花单元测试

时间:2014-08-11 20:30:50

标签: javascript angularjs unit-testing karma-runner

我是单元测试的新手,在阅读完文档之后,我仍然对如何对异步方法进行检查感到困惑,据我所知,我需要使用runs()并等待( )。但是,我可以使用spyOn来检查是否已经调用该方法,而不是这样做。

这是我要测试的代码

  $scope.createMedicalServices = function(){
        if($scope.newTreatment.async_selected_treatment.id == null){
            $scope.newTreatment.description = $scope.newTreatment.description_no_id;
        }
        else{
            $scope.newTreatment.description = $scope.newTreatment.description;
        }

      $scope.newTreatment.no_cpt_code = $scope.newTreatment.no_cpt_code;
      $scope.newTreatment.cash_price = $scope.newTreatment.cash_price_input;
      $scope.newTreatment.average_price = $scope.newTreatment.average_price_input;
      $scope.newTreatment.service = $scope.newTreatment.async_selected_treatment.service;

      var returnPromiseObject;
      if ($scope.newTreatment.no_cpt_code) {
            returnPromiseObject = ProviderMedicalService.createNew($scope.newTreatment);
      }
      else if($scope.newTreatment.async_selected_treatment.id == null){
            returnPromiseObject = ProviderMedicalService.createNewCPT($scope.newTreatment);
      }
      else{
        returnPromiseObject = ProviderMedicalService.createExisting($scope.newTreatment);
      }

      returnPromiseObject.then(
        function (value){
          $scope.newTreatment.id = value.id;
          $scope.provider_medical_services.push($scope.newTreatment);
        },
        function (error){
          console.log(error);
        });
        };

  $scope.searchTreatments = function(value){
    return Treatment.find(value).then(function(values){
      return values;
    });
  };

这是我到目前为止所写的内容,但它并不多,因为我不知道如何测试它。

  it('search treament should have been called and return a value'),function(){
  scope.searchTreatments();

}

it('it should create medical service after submitting the form'),function(){
  scope.createMedicalServices();
  runs
}

基本上,如果方法被正确调用,我很满意,因为createMedicalService函数实际上是在用户点击提交表单时执行的,因为它是html文件中ng-submit的一部分。

非常感谢帮助和建议

1 个答案:

答案 0 :(得分:1)

单元测试一开始可能有点混乱。有一些原则可以帮助进行单元测试。

目的的单一性。组件应该只做一件事。考虑将代码分成更小的部分。将逻辑从控制器移到工厂或服务中。这些可以单独测试。

控制倒置。 Angularjs在提供内置IoC方面做得非常出色。将您的依赖项作为存根,伪造或模拟传入您的单元。

仅测试界面。测试单元的内部调用结构是一种不好的做法。这最终不会测试功能,而是测试功能。相反,想想这个例子。

您有一个控制器,它获取一个名为nameService的传递的休息服务。这个控制器有一个名为submit(first,last)的方法,在调用时,应该在nameService上调用方法post(args)。

这将允许您创建nameService的存根,在post()方法上创建一个间谍并将存根传递给我们正在测试的控制器。然后你可以简单地在控制器上调用submit()并测试它是否调用了服务。

从本质上讲,您测试如果您在设备中输入内容,您的设备将按预期输出。

相关问题