1

Ich möchte den folgenden Service testen:

"use strict"; 

const BASE_API = APP_CONF.baseApi; 

export default function() { 
    "ngInject"; 

class API { 

constructor() { 
    this.loading = false; 
} 

logout() { 
    this.loading = true; 

    return $http.post(`${BASE_API}/logout`) 
    .then(res => { 
     this.loading = false; 

     return res.data; 
    }, err => { 
     this.loading = false; 

     throw err; 
    }); 
} 
} 

return new API(); 

}; 

Mein Test:

"use strict"; 

let baseApi = APP_CONF.baseApi; 

describe("Auth service", function() { 
let Auth; 

beforeEach(angular.mock.module("app")); 

beforeEach(angular.mock.inject(function(_Auth_) { 
    Auth = _Auth_; 
})); 

context("method LOGOUT", function() { 
    let $httpBackend; 

beforeEach(angular.mock.inject(function(_$httpBackend_) { 
    $httpBackend = _$httpBackend_; 
    $httpBackend.whenPOST(`${baseApi}/logout`).respond(200, { data: "ok"}); 
})); 

it("should change 'loading' flag", function() { 
    Auth.logout(); 
    assert.isTrue(Auth.loading); 
    $httpBackend.flush(); 
    assert.isFalse(Auth.loading); 
}); 

}); 
}); 

Aber mein Test nicht mit folgenden Fehler:

Chrome 51.0.2704 (Linux 0.0.0) Auth service method LOGOUT should change 'loading' flag FAILED 
    Error: Unexpected request: GET http://localhost:3000/api/mailboxes 
    No more request expected 

Diese Anforderung wird aufgerufen, nachdem die Route aufgelöst wurde:

"use strict"; 

export function config($locationProvider, $stateProvider, $urlRouterProvider) { 
    "ngInject"; 

    $urlRouterProvider.otherwise("404"); 
    $locationProvider.html5Mode(true); 

    $stateProvider 
    .state("404", { 
    url: "/404", 
    template: `<view-404 class="v-404" />` 
    }) 
    .state("home", { 
     url: "/", 
     template: `<view-home class="v-home" />`, 
     resolve: { 
     mailboxes: function(MailboxesApi, MailboxesStore, $state) { 
     "ngInject"; 

     return MailboxesApi.getAll() // THIS LINE ACTIVATES UNEXPECTED REQUEST 
     .then(mailboxes => { 
      MailboxesStore.set(mailboxes); 

      let inbox = MailboxesStore.getByName("inbox"); 

      if (inbox) { 
      $state.go("cabinet.mailbox", { mailboxid: inbox._id }); 
      } else { 
      $state.go("cabinet.mailbox", { mailboxid: MailboxesStore.getByIndex(0)._id }); 
      } 
     }); 
     } 
    } 
    }); 

    }; 

    export function run($transitions) { 
    "ngInject"; 

    $transitions.onError({ to: "*" }, (ErrorHandler, $error$) => { 
    "ngInject"; 

    ErrorHandler.handle($error$); 
    }); 

    }; 

Ich bemerkte, dass der Status 'Home' aktiviert ist, nachdem der $ httpBackend.flush() in meinem Test aufgerufen wurde. Warum passiert das?

Meine Abhängigkeiten:

  • Winkel Mocks 1.5.7
  • Winkel 1.5.6
  • Winkel-ui-Router 1.0.0-alpha.5
  • Karma 0.13.22
  • Mokka 2.5.3
  • chai 3.5.0

Antwort

2

Es scheint ein normaler Ablauf der Ausführung zu sein, nachdem die Fehlerdetails untersucht wurden. Nach dem Flush (/ logout /) wird die Weiterleitung zur Home-Ansicht entsprechend der Routing-Logik Ihres Projekts durchgeführt. Wenn es jedoch zu Hause angekommen ist, hat es etwas mit der Mailbox-API zu tun und erwartet eine weitere HTTP-Backend (GET) -Simulation.

Ich glaube, Sie eine weitere Zeile in Ihrem Testfall etwas Ähnliches wie

$httpBackend.whenGET('url').respond(200, { data: "ok"}); 
unter

sollte hinzufügen