jeudi 3 septembre 2015

AngularJS/Ionic/SinonChai - How to mock up the $ionicModal.fromTemplateUrl function

I am having trouble in my test for an ionic modal controller. The problem (or at least the problem I'm focusing on) is mocking up the $ionicModal.fromTemplateUrl function. According to ionic documentation, it's supposed to return a promise that resolves into an instance of the modal.

Here is my factory:

(function() {
  'use strict';

  angular.module('penta.app.main').factory('addEquipment', AddEquipment);

  function AddEquipment($rootScope, $ionicModal) {
    return {
      openModal: function() {
        var scope = $rootScope.$new(true);
        scope.controller = new AddEquipmentController(scope, $ionicModal);
      }
    };

    function AddEquipmentController(scope, $ionicModal) {
      var controller = this;

      $ionicModal.fromTemplateUrl('app/tracking/activityLog/addItems/equipment/addEquipment.html', {
        scope: scope,
        animation: 'slide-in-up'
      }).then(function(modal) {
        controller.modal = modal;
        controller.openModal();
      });


      controller.openModal = function() {
        controller.modal.show();
      };

      controller.closeModal = function() {
        controller.modal.hide();
      };

      return controller;
    }
  }
})();

And here is my test:

(function() {
  'use strict';

  describe('AddEquipment', function() {
    var controllerConstructor;
    var addEquipment;
    var mock;
    var mockIonicModal;
    var mockModal;
    var scope;
    var dfd;

    beforeEach(module('penta.app.main'));
    beforeEach(module('unitTest'));
    beforeEach(module('app/tracking/activityLog/addItems/equipment/addEquipment.html'));

    beforeEach(function() {
      mockModal = sinon.stub({
        show: function() {
        },

        hide: function() {
        }
      });

      mockIonicModal = sinon.stub({
        fromTemplateUrl: function() {
        },

        then: function() {
        }
      });
      mockIonicModal.fromTemplateUrl.returns(mockModal);
    });

    beforeEach(function() {
      module(function($provide) {
        $provide.value('$ionicModal', mockIonicModal);
      });
    });

    beforeEach(inject(function($rootScope, $controller, $q, ptiMock) {
      controllerConstructor = $controller;
      dfd = $q.defer();
      scope = $rootScope.$new();
      mock = ptiMock;
      mockModal.$promise = dfd.promise;
    }));

    beforeEach(inject(function(_addEquipment_) {
      addEquipment = _addEquipment_;
    }));

    it('exists', function() {
      expect(addEquipment).to.exist;
    });

    describe('open', function() {
      it.only('opens the modal', function() {
        addEquipment.openModal();
        dfd.resolve(mockModal);
        scope.$digest();

        expect(mockIonicModal.show.calledOnce).to.be.true;
      });
    });

    function getController() {
      return mockIonicModal.fromTemplateUrl.lastCall.args[0].scope.controller;
    }
  });
})();

I'm also unsure if my getController function will properly return the controller. This is my first time working with $ionicModal, so any pointers are appreciated. Thanks.

Aucun commentaire:

Enregistrer un commentaire