Можем ли да напишем модулен тест за AngularJS routeProvider?

Здравейте, изграждам приложение с помощта на AngularJS и съм заседнал в секцията за тестване на единици. Знам как да напиша модулно тестване за контролери и всичко останало, но не знам как да го направя за routeProvider. Използвам Jasmine за писане на модулен тест.

Моят доставчик на маршрут ще изглежда така;

    var app = angular.module('MyApp', ['ngResource'])

     app.config(function ($routeProvider) {
        $routeProvider
          .when('/', {
            templateUrl: 'app/views/main.html',
            controller: 'MainCtrl'
          })
          .when('/home/:PartyID', {
            templateUrl: 'app/views/home.html',
            controller: 'HomeCtrl'
          })
           .when('/edit/:PartyID', {
            templateUrl: 'app/views/update_profile.html',
            controller: 'EditCtrl'
          })
          .when('/route', {
            templateUrl: 'app/views/route.html',
            controller: 'RouteCtrl'
          })
          .when('/signup', {
            templateUrl: 'app/views/signup.html',
            controller: 'SignupCtrl'
          })
          .when('/login', {
            templateUrl: 'app/views/login.html',
            controller: 'LoginCtrl'
          })
          .otherwise({
            redirectTo: '/'
          });  
 });

Как мога да напиша модулен тест за този routeProvider с помощта на Jasmine?


person BKM    schedule 31.07.2013    source източник
comment
Предполагам, че не искате да пишете тестове за routeProvider, а вместо това да проверявате вашите URL адреси. Това е в урока docs.angularjs.org/tutorial/step_07   -  person Eduard Gamonal    schedule 31.07.2013
comment
Така че вие ​​казвате, че не е необходимо да пиша модулен тест за routeProvider, по-скоро да напиша end2end тест, за да проверя url адресите. нали   -  person BKM    schedule 31.07.2013
comment
да, routeprovider е услуга, вече тествана от момчетата от Angular. просто използвате екземпляр, за да промените обекта, който съхранява вашите url адреси.   -  person Eduard Gamonal    schedule 31.07.2013
comment
Маршрутите за тестване на модули са напълно разумни. Целта не е да се тества $routeProvider (скоро ще бъде отхвърлен), а да се тества съпоставянето между url, шаблон и контролер. Ето един пример.   -  person zhon    schedule 13.09.2013
comment
Unit test означава тестване на някаква вътрешна логика на единица от вашия код. Това, което се опитвате да направите, е да тествате конфигурация. Това е извън всичките ви единици и трябва да се тества само в тестове от край до край.   -  person hon2a    schedule 13.12.2014


Отговори (2)


Да, можете, е бързият отговор и по-долу е малко парче код, който може да се използва и разшири, за да се тества дали маршрутите ви отвеждат до местата, които очаквате.

describe('Testing routes', function() {
    beforeEach(module('windscreens'));

    var location, route, rootScope;

    beforeEach(inject(
        function( _$location_, _$route_, _$rootScope_ ) {
            location = _$location_;
            route = _$route_;
            rootScope = _$rootScope_;
    }));

     describe('Login route', function() {
        beforeEach(inject(
            function($httpBackend) {
                $httpBackend.expectGET('login')
                .respond(200);
            }));

        it('should load the login page on successful load of /login', function() {
            location.path('/login');
            rootScope.$digest();
            expect(route.current.controller).toBe('LoginCtrl')
        });
    });    
});
person Nick Lewis    schedule 23.04.2014
comment
Здравей Ник, благодаря за този директен пример. Това ми прилича повече на поведенчески тест, вместо на единицен тест. - person Greg Wang; 03.06.2014
comment
Хммм @GregWang имаш право. Jasmine е повече BDD език отколкото TDD имайте предвид. - person Nick Lewis; 06.06.2014

Не го усложнявай

describe('Testing Routes', function () {

// load the controller's module
beforeEach(module('MyApp'));

it('should test routes',
inject(function ($route) {

  expect($route.routes['/'].controller).toBe('MainCtrl');
  expect($route.routes['/'].templateUrl).toEqual('app/views/main.html');

  expect($route.routes['/home/:PartyID'].controller).toBe('HomeCtrl');
  expect($route.routes['/home/:PartyID'].templateUrl).toEqual('app/views/home.html');

  expect($route.routes['/edit/:PartyID'].controller).toBe('EditCtrl');
  expect($route.routes['/edit/:PartyID'].templateUrl).toEqual('app/views/update_profile.html');

  expect($route.routes['/route'].controller).toBe('RouteCtrl');
  expect($route.routes['/route'].templateUrl).toEqual('app/views/route.html');

  expect($route.routes['/signup'].controller).toBe('SignupCtrl');
  expect($route.routes['/signup'].templateUrl).toEqual('app/views/signup.html');

  expect($route.routes['/streamconfigs/:id'].controller).toBe('LoginCtrl');
  expect($route.routes['/streamconfigs/:id'].templateUrl).toEqual('app/views/login.html');

  expect($route.routes[null].redirectTo).toEqual('/');
}));

});
person Joey Gutierrez    schedule 13.12.2014