我在项目上实现了一个简单的集成测试,但是失败了,因为expect()行在component.save()方法之前执行。当我将expect()行放在setTimeout()上时,它就成功了。没有setTimeout()如何成功?
spec.ts
import { Observable } from 'rxjs/Rx';
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { By } from '@angular/platform-browser';
import { DebugElement } from '@angular/core';
import { Router, ActivatedRoute } from '@angular/Router';
import { UserDetailsComponent } from './user-details.component';
import { RouterTestingModule } from '@angular/router/testing';
class RouterStub {
navigate(params) { };
}
class ActivatedRouteStub {
params: Observable<any> = Observable.empty();
}
describe('UserDetailsComponent', () => {
let component: UserDetailsComponent;
let fixture: ComponentFixture<UserDetailsComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [RouterTestingModule],
declarations: [UserDetailsComponent],
providers: [
{ provide: Router, useClass: RouterStub },
{ provide: ActivatedRoute, useClass: ActivatedRouteStub }
],
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(UserDetailsComponent);
component = fixture.componentInstance;
});
it('should redirect the user to the users page after saving', () => {
let router = TestBed.get(Router);
let spy = spyOn(router, 'navigate');
component.save();
expect(spy).toHaveBeenCalledWith(['users']);
});
});
错误:
Expected spy navigate to have been called with [ [ 'users' ] ] but it was never called
答案 0 :(得分:3)
我遇到了同样的问题,我通过创建mockRouter解决了问题并检查了方法nav()
。
此HomeComponent
是着陆组件,AppComponent
采用router.navigate
方法。
在我的app.component.ts
nav() {
this.router.navigate(['/home']);
}
我的app.component.spec.ts
import { TestBed, async, ComponentFixture, fakeAsync, tick,inject } from '@angular/core/testing';
import { By, BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { HomeComponent } from './home/home.component';
import { RouterModule, Routes } from '@angular/router';
import { Router, RouterOutlet,ActivatedRoute } from "@angular/router";
import { RouterTestingModule } from '@angular/router/testing';
import * as br from '@angular/platform-browser';
describe('Component:AppComponent', () => {
let component: AppComponent;
let fixture: ComponentFixture<AppComponent>;
let debugElement: DebugElement;
let location, router: Router;
let mockRouter;
beforeEach(() => {
mockRouter = { navigate: jasmine.createSpy('navigate') };
TestBed.configureTestingModule({
imports: [RouterTestingModule.withRoutes([
{ path: 'home', component: HomeComponent }
])],
declarations: [AppComponent, HomeComponent],
providers: [
{ provide: Router, useValue: mockRouter},
]
});
});
beforeEach(() => {
fixture = TestBed.createComponent(AppComponent);
component = fixture.componentInstance;
debugElement = fixture.debugElement;
});
it('should go home', async(() => {
fixture.detectChanges();
component.nav();
expect(mockRouter.navigate).toHaveBeenCalledWith(['/home']);
}));
});