Table des matières
Test unitaire
Test de fonction
Instruction structurelle Test HostListener
Make. bon usage des modificateurs public, private et protected
Test de l'événement de clic
Maison interface Web js tutoriel 4 conseils pour rédiger des tests unitaires angulaires, venez jeter un oeil !

4 conseils pour rédiger des tests unitaires angulaires, venez jeter un oeil !

Aug 11, 2022 pm 08:22 PM
angular 单元测试

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 !

4 conseils pour rédiger des tests unitaires angulaires, venez jeter un oeil !

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(); 
});
Copier après la connexion

Test de fonction

1 Appel de fonction sans valeur de retour

function test(index:number ,fn:Function){
 if(fn){
     fn(index);
 }
}
Copier après la connexion

Comment tester ?

Contre-exemple : tester directement la valeur de retour non définie

  const res = component.test(1,() => {}));
  expect(res).tobeUndefined();
Copier après la connexion

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();
 })
Copier après la connexion

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';
  } 
}
Copier après la connexion

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()方法就会被执行到
});
Copier après la connexion

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>`
Copier après la connexion

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);
});
Copier après la connexion

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Pratiques de tests unitaires pour les interfaces et les classes abstraites en Java Pratiques de tests unitaires pour les interfaces et les classes abstraites en Java May 02, 2024 am 10:39 AM

É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.

La différence entre les tests de performances et les tests unitaires en langage Go La différence entre les tests de performances et les tests unitaires en langage Go May 08, 2024 pm 03:09 PM

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 des avantages et inconvénients des outils de tests unitaires PHP Analyse des avantages et inconvénients des outils de tests unitaires PHP May 06, 2024 pm 10:51 PM

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é.

Comment utiliser la méthode de test basée sur des tables dans les tests unitaires Golang ? Comment utiliser la méthode de test basée sur des tables dans les tests unitaires Golang ? Jun 01, 2024 am 09:48 AM

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é.

Quelle est la différence entre les tests unitaires et les tests d'intégration dans les tests de fonctions Golang ? Quelle est la différence entre les tests unitaires et les tests d'intégration dans les tests de fonctions Golang ? Apr 27, 2024 am 08:30 AM

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.

Tests unitaires PHP : comment concevoir des cas de test efficaces Tests unitaires PHP : comment concevoir des cas de test efficaces Jun 03, 2024 pm 03:34 PM

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.

Tests unitaires PHP : conseils pour augmenter la couverture du code Tests unitaires PHP : conseils pour augmenter la couverture du code Jun 01, 2024 pm 06:39 PM

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.

Intégration des tests unitaires PHP et de la livraison continue Intégration des tests unitaires PHP et de la livraison continue May 06, 2024 pm 06:45 PM

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.

See all articles