sun*_*nil 5 typescript viewchild angular angular-unit-test
我的组件文件有以下代码
@ViewChild('clusterCard', { static: false }) clusterCard: ElementRef;
highLightTheClusterCard(point: PickupClusterPoint) {
if (point) {
const card: HTMLElement = _get(this.clusterCard, 'nativeElement');
const selectedPoint: PositioningPoint = this.lane.data.selectedPostioningPoint;
/* if card is available, position point of the card and the cluster is same and infowindow over the cluster is open then
highlight the card */
if (card && _isEqual(point.pointData, selectedPoint) && point.openInfoWindow) {
card.scrollIntoView();
card['style'].borderLeft = `5px solid ${this.lane.data.color || 'transparent'}`;
} else {
card['style'].borderLeft = `5px solid transparent`;
}
}
}
ngAfterViewChecked(): void {
...some code
this.pickupClusterPointsService.positioningPoint$
.pipe(skip(1), takeUntil(this.unsubscriber.done))
.subscribe((point: PickupClusterPoint) => {
this.highLightTheClusterCard(point);
});
}
Run Code Online (Sandbox Code Playgroud)
HTML文件
<div #clusterCard>
<pickup-cluster-stop-card
..some code
>
</pickup-cluster-stop-card>
</div>
Run Code Online (Sandbox Code Playgroud)
我想对 highLightTheClusterCard 方法进行单元测试。我正进入(状态
类型错误:无法读取未定义错误属性的属性“管道”
和类型错误:无法设置未定义的属性“borderLeft”
单元测试文件
beforeEach(() => {
...some code
fixture = TestBed.createComponent(RouteLaneComponent);
component = fixture.componentInstance;
....some code
fixture.detectChanges();
});
fdescribe('highLightTheClusterCard', () => {
it('should expect cluster card to be defined ', () => {
// component.clusterCard.nativeElement = new HTMLElement();
component.clusterCard = new ElementRef({ nativeElement: jasmine.createSpyObj('nativeElement', ['scrollIntoView', 'style'])});
component.highLightTheClusterCard({ pointData: new PositioningPoint(), openInfoWindow: true} as PickupClusterPoint);
// expect(component.clusterCard).toBeDefined();
// expect(component.clusterCard.nativeElement.scrollIntoView).toHaveBeenCalled();
});
});
Run Code Online (Sandbox Code Playgroud)
我读了这个如何在 Angular 4 规范文件中模拟 nativeElement.focus()
但是,我仍然无法使它变绿。
MockService(PickupClusterPointsService, {
...more code
positioningPoint$: of(undefined),
}),
Run Code Online (Sandbox Code Playgroud)
解决方案:我添加positioningPoint$: of(undefined)了模拟服务。MockService 位于 Provider 内部。你可以看到上面的线条。
describe('highLightTheClusterCard', () => {
it('should expect cluster card to be highlighted when hover over infowindow ', () => {
component.lane.data.selectedPostioningPoint = new PositioningPoint();
component.lane.data.color = '#2196F3';
component.clusterCard = {
nativeElement: jasmine.createSpyObj('nativeElement', ['scrollIntoView', 'style'])
};
component.highLightTheClusterCard({ pointData: new PositioningPoint(), openInfoWindow: true} as PickupClusterPoint);
expect(component.clusterCard).toBeDefined();
expect(component.clusterCard.nativeElement.scrollIntoView).toHaveBeenCalled();
expect(component.clusterCard.nativeElement.style.borderLeft).toBe('5px solid #2196F3');
});
it('should expect cluster card not to be highlighted when hover out from the infowindow', () => {
component.lane.data.selectedPostioningPoint = new PositioningPoint();
component.clusterCard = {
nativeElement: jasmine.createSpyObj('nativeElement', ['scrollIntoView', 'style'])
};
component.highLightTheClusterCard({ pointData: new PositioningPoint(), openInfoWindow: false} as PickupClusterPoint);
expect(component.clusterCard).toBeDefined();
expect(component.clusterCard.nativeElement.style.borderLeft).toBe('5px solid transparent');
});
});
Run Code Online (Sandbox Code Playgroud)
你似乎有几个问题。
你的第一个错误
TypeError:无法读取未定义错误属性的属性“管道”
来自您尚未正确实例化您的pickupClusterPointsService 服务。
第二个错误
类型错误:无法设置未定义的属性“borderLeft”
我还不确定
| 归档时间: |
|
| 查看次数: |
1784 次 |
| 最近记录: |