Unit testing controller which uses $state.transitionTo

后端 未结 3 1729
小蘑菇
小蘑菇 2021-01-11 10:02

within a controller i have a function which uses $state.transitionTo to \"redirect\" to another state.

now i am stuck in testing this function, i get al

相关标签:
3条回答
  • 2021-01-11 10:18

    I recently asked this question as a github issue and it was answered very helpfully. https://github.com/angular-ui/ui-router/issues/537

    You should do a $rootScope.$apply() and then be able to test. Note that by default if you use templateUrl you will get an "unexpected GET request" for the view, but you can resolve this by including your templates into your test.

    'use strict';
    
    describe('Controller: CourseCtrl', function () {
    
      // load the controller's module
      beforeEach(module('myApp'));
    
      // load controller widgets/views/partials
      var views = [
        'views/course.html',
        'views/main.html'
      ];
    
      views.forEach(function(view) {
        beforeEach(module(view));
      });
    
      var CourseCtrl,
        scope;
    
      // Initialize the controller and a mock scope
      beforeEach(inject(function ($controller, $rootScope) {
        scope = $rootScope.$new();
        CourseCtrl = $controller('CourseCtrl', {
          $scope: scope
        });
      }));
    
      it('should should transition to main.course', inject(function ($state, $rootScope) {
        $state.transitionTo('main.course');
        $rootScope.$apply();
        expect($state.current.name).toBe('main.course');
      }));
    });
    
    0 讨论(0)
  • 2021-01-11 10:34

    Disclaimer: I haven't done this myself, so I totally don't know if it will work and is what your are after.

    From the top of my head, two solutions come to my mind.

    1.) In your tests pre configure the $stateProvider to return a mocked state for the state-two That's also what the ui-router project itself does to test state transitions.

    See: https://github.com/angular-ui/ui-router/blob/04d02d087b31091868c7fd64a33e3dfc1422d485/test/stateSpec.js#L29-L42

    2.) catch and parse the exception and interpret it as fulfilled test if tries to get to state-two

    The second approach seems very hackish, so I would vote for the first.

    However, chances are that I totally got you wrong and should probably get some rest.

    Solution code:

    beforeEach(module(function ($stateProvider) { 
      $stateProvider.state('state-two', { url: '/' }); 
    }));
    
    0 讨论(0)
  • 2021-01-11 10:37

    Also if you want to expect on that the transition was made like so

    expect(state.current.name).toEqual('state-two')
    

    then you need to scope.$apply before the expect() for it to work

    0 讨论(0)
提交回复
热议问题