Это мой первый опыт тестирования angular. Я использую для этого Жасмин и Карму. Трюк в том, что этот тест на самом деле проходит, и я вижу его в отчете о покрытии. Но проверка выдает ошибку «Spe c». AppComponent должен проверить, что функция closeMenus () «не имеет ожиданий». хоть. У меня есть следующий код:
app.components.ts
import { Component, ViewChild, Directive } from '@angular/core';
import { MatSidenav } from '@angular/material';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'myApp';
@ViewChild('sidenav', {static:true}) sidenavbar : MatSidenav;
openmenu : string = "";
closeMenus() {
this.sidenavbar.close();
}
}
app.component.spe c .ts
import { AppComponent } from './app.component';
import { TestBed, async, fakeAsync } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import * as material from '@angular/material';
describe('AppComponent', async() => {
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [
RouterTestingModule,
material.MatAutocompleteModule,
...
material.MatTooltipModule,
],
declarations: [
AppComponent,
],
}).compileComponents();
}));
// works but SPEC HAS NO EXPECTATIONS
it('should check function closeMenus()', (() => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.debugElement.componentInstance;
spyOn(app.sidenavbar, 'close');
app.closeMenus();
expect(app.sidenavbar.close).toHaveBeenCalled;
}));
});
Я что-то здесь не так делаю?
Спасибо за помощь и хорошего дня :)