AngularComment effectuer des tests unitaires ? Dans cet article, je vais partager avec vous 4 techniques de haut niveau pour rédiger des tests unitaires angulaires. J'espère que cela vous sera utile !
Idées de tests :
La difficulté des tests augmente progressivement et plus cela prend de temps. Si vous souhaitez simplifier les tests, pendant le développement, vous devez consciemment clarifier vos idées et écrire un code simple et efficace ~.
La pile technologique de test utilisée dans cet article : Angular12 +Jasmine Bien que la syntaxe des autres technologies de test soit différente, l'idée générale est similaire. [Recommandations de tutoriel associées : "Tutoriel angulaire"]
Conseils : Détermination des cas de test Jasmine, quelles sont les méthodes, vous pouvez les trouver ici, Poke me
La valeur par défaut est composant L'instance de l'objet à tester créée par Angular en utilisant la syntaxe suivante
beforeEach(() => { fixture = TestBed.createComponent(BannerComponent); component = fixture.componentInstance; fixture.detectChanges(); });
1 Appel de fonction sans valeur de retour
function test(index:number ,fn:Function){ if(fn){ fn(index); } }
Comment tester ?
Contre-exemple : tester directement la valeur de retour non définie
const res = component.test(1,() => {})); expect(res).tobeUndefined();
Pratique recommandée :
# 利用Jasmine it('should get correct data when call test',() =>{ const param = { fn:() => {} } spyOn(param,'fn') component.test(1,param.fn); expect(param.fn).toHaveBeenCalled(); })
Instruction structurelle, termes courants cacher, afficher et boucle for pour afficher de telles fonctions
# code @Directive({ selector: '[ImageURlError]' }) export class ImageUrlErrorDirective implements OnChanges { constructor(private el: ElementRef) {} @HostListener('error') public error() { this.el.nativeElement.style.display = 'none'; } }
Comment tester ?
Idée de test :
#1.添加一个自定义组件, 并添加上自定义指令 @Component({ template: `<div> <image src="https://xxx.ss.png" ImageURlError></image> </div>` }) class TestHostComponent { } #2.把自定义组件视图实例化,并派发errorEvent beforeEach(waitForAsync(() => { TestBed.configureTestingModule({ declarations: [ TestHostComponent, ImageURlError ] }); })); beforeEach(() => { fixture = TestBed.createComponent(TestHostComponent); component = fixture.componentInstance; fixture.detectChanges(); }); it('should allow numbers only', () => { const event = new ErrorEvent('error', {} as any); const image = fixture.debugElement.query(By.directive(ImageURlError)); image.nativeElement.dispatchEvent(event); //派发事件即可,此时error()方法就会被执行到 });
En angulaire, spec.ts est accessible s'il est public cependant, s'il est privé ou protégé, il n'est pas accessible
Frappez sur le ; tableau noir
Déclenchement de l'événement de clic, il y a un clic d'appel direct js, et également l'imitation de la souris pour déclencher l'événement de clic.
# xx.component.ts @Component({ selecotr: 'dashboard-hero-list' }) class DashBoardHeroComponent { public cards = [{ click: () => { ..... } }] } # html <dashboard-hero-list [cards]="cards" class="card"> </dashboard-hero-list>`
Comment tester ?
Idée de test :
it('should get correct data when call click',() => { const cards = component.cards; cards?.forEach(card => { if(card.click){ card.click(new Event('click')); } }); expect(cards?.length).toBe(1); });
Idées de référence pour d'autres clics :
Idée 1 :
Idée 2 :
Testez le composant directement sans utiliser Host
Utilisez ensuite luminaire.nativeElement.querySelector('.card') pour trouver l'élément de clic lié ;
Utilisez triggerEventHandler ('click');
Pour plus de connaissances sur la programmation, veuillez visiter : Vidéo de programmation ! !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!