別のサービスを使用するコンポーネントをテストしようとしています。そして私はサービスのモックを提供することによってコンポーネントを分離したいと思っています。 RC5の前に私は単純にaddproviders
を使うことができます。これは廃止され、次のRCで削除されます。代わりにTestBed
を使用する必要があります。私が何らかの理由でモック角を提供すると、モックが依存するサービスを探し続ける。 DI exception
を投げます。すべての依存関係を提供するとテストは機能しますが、テストスイートごとに自分自身を繰り返す必要はありません。そして、これは基本的なオブジェクト指向の原則を破ります。 私のテストスイート:モック付き角2 TestBed
describe('Component: DummyRestApi',() => {
class DummyRestApiTestService {
GetAll() {
return Rx.Observable.create(observer => {
let data:Data[] = [];
data.push({
id: 0,
data: 'data'
});
observer.next(data);
observer.complete();
});
}
Add(data) {
}
}
let fixture;
let myMockWindow:Window;
// ToDo use the mocks
beforeEach(() => {
myMockWindow = <any> {location: <any> {hostname: '127.0.0.1'}};
TestBed.configureTestingModule({
declarations: [DummyRestApiComponent],
providers: [
// ServerAddressResolverService,
DummyRestApiComponent,
// ConfigurationService,
{provide: DummyRestApiService, useClass: DummyRestApiTestService},
// {provide: Window, useValue: myMockWindow}
],
imports: [FormsModule, HttpModule]
});
TestBed.compileComponents().catch(error => console.error(error));
// addProviders([
// DummyRestApiComponent,
// {provide: DummyRestApiService, useClass: DummyRestApiTestService},
// ]);
});
describe('Initializing',() => {
beforeEach(async(() => {
console.log('Compiling');
TestBed.compileComponents().catch(error => console.error(error));
console.log('Compiling again');
}));
it('should create an instance', async(() => {
var fixture = TestBed.createComponent(DummyRestApiComponent);
fixture.detectChanges();
expect(fixture.debugElement.componentInstance).toBeTruthy();
}
));
});
角度2.0.0-RC5私はちょうどRC5に私のシードプロジェクトを更新しました
を私はこれを確認しました。あたかも黙っていないかのように、サービスのインポートを指定する必要があります。少なくともRC5では。しかし、テストではモックサービスを使用します。 – Dave