web-dev-qa-db-fra.com

Fournisseur non valide pour le NgModule 'DynamicTestModule' lors du test d'un service dans Angular 2

J'ai le service suivant:

import { Injectable } from '@angular/core';

import { MenuItem } from './../classes/menu-item';
import { ITEMS } from './../static-data/items-list';

@Injectable()
export class ItemsListService {

    getItems(): Promise<MenuItem[]> {
        return Promise.resolve(ITEMS);
    }

}

Le test de ce service est ici:

import { TestBed, async, inject } from '@angular/core/testing';

import { ItemListService } from './item-list.service';
import { MenuItem } from './../classes/menu-item';
import { ITEMS } from './../static-data/items-list';

describe('ItemListService', () => {
  beforeEach(() => {
    TestBed.configureTestingModule({
        providers: [ ItemListService, MenuItem, ITEMS ]
    });
  });

  it('should ...', inject([ItemListService], (service: ItemListService) => {
    expect(service).toBeTruthy();
  }));
});

Le MenuItem est défini ici:

export class MenuItem {
    name: string;
    link: string;
}

ITEMS est défini ici: import {MenuItem} de './../classes/menu-item';

export var ITEMS: MenuItem[] = [
    {name: 'Vehicles', link: '/vehicles'},
    {name: 'Gateways', link: '/gateways'},
    {name: 'Statuses', link: '/statuses'},
    {name: 'Logs', link: '/logs'}
]

Lorsque j'exécute le test, je reçois dans la console des navigateurs les erreurs suivantes:

FAILED ItemListService should ...

et

enter image description here

Alors pourquoi ai-je ces erreurs? Et quelle est la solution pour que le test fonctionne?

14
Cristian

C'est une erreur tellement ennuyeuse, j'ai pensé inclure une autre cause subtile à rechercher dans vos spécifications. Dans mon cas, j'ai spécifié "fournisseur" au lieu de "fournir" comme ci-dessous

 TestBed.configureTestingModule({
      providers: [{provider: ApplicationActions, useClass: ActionMock}]

plutôt que d'offrir des informations utiles comme "aucune clé" fournir "spécifiée", il signale simplement

Failed: Invalid provider for the NgModule 'DynamicTestModule' - only instances of Provider and Type are allowed, got: [?[object Object]?, ...]
48
Craig