


4 conseils pour rédiger des tests unitaires angulaires, venez jeter un oeil !
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 :
- 1. Si les tests unitaires sont possibles, essayez de donner la priorité aux tests unitaires
- 2 Si les tests unitaires ne sont pas possibles, testez via une couche d'encapsulation, par exemple en encapsulant le test. dans un composant, mais il existe des tests plus faibles que les tests d'intégration
- 3 Tests d'intégration
- 4 Tests E2E
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
Test unitaire
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(); });
Test de fonction
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 Test HostListener
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 :
- L'erreur de chargement de l'image se déclenche, puis trouvez un moyen de déclencher l'erreur
- Les commandes sont généralement attachées aux composants sur l'élément image du composant, utilisez simplement errorEvent sous dispath
#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()方法就会被执行到 });
Make. bon usage des modificateurs public, private et protected
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
- Si vous envisagez de faire des tests unitaires et de tester les méthodes une par une, veuillez utiliser public de manière appropriée --- Difficulté *
- Si vous ne prévoyez pas de tester chaque méthode, vous pouvez organiser les données, appeler l'entrée , et passez la méthode par les tests d'intégration -- Difficulté ***
Test de l'événement de clic
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 :
- Testez le composant directement sans utiliser Host
- Utilisez la collection d'objets contenant des événements de clic renvoyés par le code pour appeler click un par un, afin que la couverture du code soit améliorée
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 :
- Utilisez TestHostComponent pour envelopper le composant qui doit être testé
- Utilisez ensuite luminaire.nativeElement.querySelector('.card') pour trouver l'élément de clic lié au composant ;
- Déclenchez dispatchEvent sur l'élément, c'est-à-dire Oui,
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Étapes pour les interfaces de tests unitaires et les classes abstraites en Java : Créez une classe de test pour l'interface. Créez une classe fictive pour implémenter les méthodes d'interface. Utilisez la bibliothèque Mockito pour simuler les méthodes d'interface et écrire des méthodes de test. La classe abstraite crée une classe de test. Créez une sous-classe d'une classe abstraite. Écrivez des méthodes de test pour tester l'exactitude des classes abstraites.

Les tests de performances évaluent les performances d'une application sous différentes charges, tandis que les tests unitaires vérifient l'exactitude d'une seule unité de code. Les tests de performances se concentrent sur la mesure du temps de réponse et du débit, tandis que les tests unitaires se concentrent sur la sortie des fonctions et la couverture du code. Les tests de performances simulent des environnements réels avec une charge et une concurrence élevées, tandis que les tests unitaires s'exécutent dans des conditions de faible charge et en série. L'objectif des tests de performances est d'identifier les goulots d'étranglement des performances et d'optimiser l'application, tandis que l'objectif des tests unitaires est de garantir l'exactitude et la robustesse du code.

Analyse de l'outil de test unitaire PHP : PHPUnit : convient aux grands projets, fournit des fonctionnalités complètes et est facile à installer, mais peut être verbeux et lent. PHPUnitWrapper : adapté aux petits projets, facile à utiliser, optimisé pour Lumen/Laravel, mais a des fonctionnalités limitées, ne fournit pas d'analyse de couverture de code et dispose d'un support communautaire limité.

Les tests basés sur des tables simplifient l'écriture de scénarios de test dans les tests unitaires Go en définissant les entrées et les sorties attendues via des tableaux. La syntaxe comprend : 1. Définir une tranche contenant la structure du scénario de test ; 2. Parcourez la tranche et comparez les résultats avec la sortie attendue. Dans le cas réel, un test basé sur une table a été effectué sur la fonction de conversion de chaîne en majuscules, et gotest a été utilisé pour exécuter le test et le résultat de réussite a été imprimé.

Les tests unitaires et les tests d'intégration sont deux types différents de tests de fonctions Go, utilisés respectivement pour vérifier l'interaction et l'intégration d'une seule fonction ou de plusieurs fonctions. Les tests unitaires testent uniquement les fonctionnalités de base d'une fonction spécifique, tandis que les tests d'intégration testent l'interaction entre plusieurs fonctions et l'intégration avec d'autres parties de l'application.

Il est crucial de concevoir des cas de tests unitaires efficaces, en adhérant aux principes suivants : atomiques, concis, reproductibles et sans ambiguïté. Les étapes comprennent : la détermination du code à tester, l'identification des scénarios de test, la création d'assertions et l'écriture de méthodes de test. Le cas pratique démontre la création de cas de test pour la fonction max(), en soulignant l'importance des scénarios de test et des assertions spécifiques. En suivant ces principes et étapes, vous pouvez améliorer la qualité et la stabilité du code.

Comment améliorer la couverture du code dans les tests unitaires PHP : utilisez l'option --coverage-html de PHPUnit pour générer un rapport de couverture. Utilisez la méthode setAccessible pour remplacer les méthodes et propriétés privées. Utilisez des assertions pour remplacer les conditions booléennes. Obtenez des informations supplémentaires sur la couverture du code grâce aux outils de révision du code.

Résumé : En intégrant le framework de tests unitaires PHPUnit et le pipeline CI/CD, vous pouvez améliorer la qualité du code PHP et accélérer la livraison des logiciels. PHPUnit permet la création de scénarios de test pour vérifier la fonctionnalité des composants, et les outils CI/CD tels que GitLabCI et GitHubActions peuvent exécuter automatiquement ces tests. Exemple : validez le contrôleur d'authentification avec des cas de test pour garantir que la fonctionnalité de connexion fonctionne comme prévu.
