我是刚开始在Angular 6应用中使用Karma / Jasmine进行测试的人,可以为我最常见的故障之一提供帮助。
这是我模板中“ RouterLink”的使用和配置。我运行该应用程序没有错误,但是在运行测试时,我收到了错误消息:
Can't bind to 'routerLink' since it isn't a known property of 'a'.
我不能完全正确地配置我的规范文件。关于如何在运行测试时如何修复配置以修复该错误的任何想法?我不确定app.module文件,组件或测试文件是否有问题。
import { NavigationComponent } from '../navigation/navigation.component';
import { EditMonitoringPointComponent } from './edit-monitoring-point.component';
import { FormsModule, NgModel } from '@angular/forms';
import { RouterLink, RouterModule } from '@angular/router';
import { NgModule } from '@angular/core';
describe('EditMonitoringPointComponent', () => {
let component: EditMonitoringPointComponent;
let fixture: ComponentFixture<EditMonitoringPointComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [ FormsModule],
declarations: [ EditMonitoringPointComponent, NavigationComponent],
providers: [ RouterModule, RouterLink],
// directives: [ROUTER_DIRECTIVES]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(EditMonitoringPointComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
这是html中正在捕获的行:
<a [routerLink]="['/sites', current_mp.siteId]" ><i class='fa fa-ban'></i> Cancel</a>
我的组件看起来像:
import { ActivatedRoute, ParamMap, Router, RouterModule, RouterLink } from '@angular/router';
import { SiteService } from '../../services/site.service'
import { MonitoringPointService } from '../../services/monitoring-point.service'
import { AuthService } from '../../services/auth.service'
import { DeviceService } from '../../services/device.service';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
@Component({
selector: 'app-edit-monitoring-point',
templateUrl: './edit-monitoring-point.component.html',
styleUrls: ['./edit-monitoring-point.component.css']
})
export class EditMonitoringPointComponent implements OnInit {
//declare variables
}
constructor(private router: Router, private monitoringPointService: MonitoringPointService, public dialog: MatDialog, private deviceService: DeviceService, public siteService: SiteService, private route: ActivatedRoute, private SiteService: SiteService, private authService: AuthService) { }
ngOnInit() {
...
}
app.module.ts
import { NgModule } from '@angular/core';
import {
RouterModule} from '@angular/router';
import { AppRoutingModule, routingComponents } from './app-routing.module';
import { FormsModule } from '@angular/forms';
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
import { AppComponent } from './app.component';
@NgModule({
declarations: [
AppComponent,
routingComponents],
imports: [
RouterModule,
BrowserModule,
AppRoutingModule,
FormsModule,
HttpClientModule,],
providers: [
{provide: HTTP_INTERCEPTORS,
useClass: UnauthorizedResponseInterceptor,
multi: true}]
})
export class AppModule { }
platformBrowserDynamic().bootstrapModule(AppModule);
Thank you so much!
答案 0 :(得分:1)
您应该在您的spec文件中将RouterTestingModule添加到您的导入中。 那应该允许Angular识别您的routerLink指令。 还要清除提供者数组。
有关更多信息,请参考本教程: https://codecraft.tv/courses/angular/unit-testing/routing/
如果对组件内部的路由“测试”不感兴趣,您只需将NO_ERROR_SCHEMA添加到configureTestingModule方法中即可。
schemas: [NO_ERRORS_SCHEMA]