Тестирование компонента, который зависит от параметра маршрута
У меня есть вопрос о тестировании маршрутизируемого компонента в angular2.
Вот простой компонент, который зависит от маршрута с параметром 'foo'
, Атрибут foo
в компоненте будет установлено значение параметра.
import {Component, OnInit} from '@angular/core';
import {ActivatedRoute, Params} from '@angular/router';
@Component({
selector: 'my-component',
templateUrl: './my-component.html'
})
export class MyComponent implements OnInit
{
foo: string;
constructor(
private route: ActivatedRoute
)
{
}
ngOnInit()
{
this.route.params.subscribe((params: Params) => {
this.foo = params['foo'];
});
}
}
Теперь я хочу проверить, что, если компонент будет создан с маршрутом, параметр будет установлен правильно. Так что где-то я хочу иметь expect(component.foo).toBe('3');
,
import {TestBed, ComponentFixture, async} from '@angular/core/testing';
import {DebugElement} from '@angular/core';
import {By} from '@angular/platform-browser';
import {Params, ActivatedRoute} from '@angular/router';
import {Observable} from 'rxjs';
import {MyComponent} from './MyComponent';
describe('MyComponent', () => {
let mockParams, mockActivatedRoute;
let component: MyComponent;
let fixture: ComponentFixture<MyComponent>;
let debugElement: DebugElement;
let element: HTMLElement;
beforeEach(async(() => {
mockParams = Observable.of<Params>({foo: '3'});
mockActivatedRoute = {params: mockParams};
TestBed.configureTestingModule({
declarations: [
MyComponent
],
providers: [
{provide: ActivatedRoute, useValue: mockActivatedRoute}
]
}).compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(MyComponent);
component = fixture.componentInstance;
debugElement = fixture.debugElement;
element = debugElement.nativeElement;
fixture.detectChanges();
});
it('should set foo to "3"', () => {
expect(component.foo).toBe('3');
});
});
Моя проблема в том, что я не знаю, как ждать, пока не закончится разрешение маршрута, и я могу сделать expect()
, И в этом примере тест не пройден, и он говорит: "Ожидается, что неопределенное значение будет равно 3".
Может кто-то помочь мне, пожалуйста?!
Спасибо!
1 ответ
Хорошо, прочитав немного в документации тестирования angular2, я увидел их ActivatedRouteStub
учебный класс. Я создал этот класс заглушки и заменил мою оригинальную макет этим новым классом. Теперь это работает (распознать строку mockActivatedRoute.testParams = {foo: '3'};
во втором до каждого).
import {TestBed, ComponentFixture, async} from '@angular/core/testing';
import {DebugElement} from '@angular/core';
import {By} from '@angular/platform-browser';
import {Params, ActivatedRoute} from '@angular/router';
import {Observable} from 'rxjs';
import {MyComponent} from './MyComponent';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
@Injectable()
export class ActivatedRouteStub
{
private subject = new BehaviorSubject(this.testParams);
params = this.subject.asObservable();
private _testParams: {};
get testParams() { return this._testParams; }
set testParams(params: {}) {
this._testParams = params;
this.subject.next(params);
}
}
describe('MyComponent', () => {
let mockParams, mockActivatedRoute;
let component: MyComponent;
let fixture: ComponentFixture<MyComponent>;
let debugElement: DebugElement;
let element: HTMLElement;
beforeEach(async(() => {
mockActivatedRoute = new ActivatedRouteStub();
TestBed.configureTestingModule({
declarations: [
MyComponent
],
providers: [
{provide: ActivatedRoute, useValue: mockActivatedRoute}
]
}).compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(MyComponent);
component = fixture.componentInstance;
debugElement = fixture.debugElement;
element = debugElement.nativeElement;
mockActivatedRoute.testParams = {foo: '3'};
fixture.detectChanges();
});
it('should set foo to "3"', () => {
expect(component.foo).toBe('3');
});
});
Как вы думаете, это правильный путь?