Karma和Ionic上的CordovaCamera选项

时间:2016-03-11 11:18:18

标签: angularjs cordova unit-testing ionic-framework karma-runner

我正在为我的Ionic应用程序编写单元测试,并在测试相机相关功能时遇到问题。我的代码使用由cordova.js设置的两个全局变量:相机 CameraPopoverOptions 。由于文件仅插入到实际的移动设备上,因此当测试需要它们时,它们都是undefined。我应该在哪里获得这两个变量用于测试,还是应该找出它们的值并对它们进行硬编码?

.factory('Camera', ['$q', '$cordovaCamera', '$window', function($q, $cordovaCamera, $window) {

  return {
    getPicture: function(options) {
      if(!$window.cordova) {
        // We are in dev mode, let's return a kickass Ferrari
        var q = $q.defer();
        q.resolve('/img/ferrari.jpg');
        return q.promise;
      }

      var options = { 
          quality : 75, 
          destinationType : Camera.DestinationType.FILE_URI, 
          sourceType : Camera.PictureSourceType.CAMERA, 
          allowEdit : false,
          encodingType: Camera.EncodingType.JPEG,
          targetWidth: 1024,
          targetHeight: 1024,
          correctOrientation: true,
          popoverOptions: CameraPopoverOptions,
          saveToPhotoAlbum: false
      };      

      // Returns a promise
      return $cordovaCamera.getPicture(options);
    }
  }
}])

1 个答案:

答案 0 :(得分:0)

我认为你不应该通过在那里硬编码法拉利来改变你的代码,而是在你的测试中使用$ cordovaCamera的模拟。您可以结帐https://github.com/ecofic/ngCordovaMocks

或结帐http://cgewecke.github.io/ionic-karma-guide/以获取更实用的指南。