CLI angulaire - commande ng test

Syntaxe

ng test <project> [options]
ng t <project> [options]

ng test exécutez les cas de test unitaires sur le code d'application angulaire. Les options sont des paramètres facultatifs.

Arguments

Sr.No. Argument et syntaxe La description
1 <projet> Le nom du projet à tester.

Options

Sr.No. Option et syntaxe La description
1 --browsers = navigateurs Remplacez les tests sur lesquels les navigateurs sont exécutés.
2 --codeCoverage = true | false

Produisez un rapport de couverture de code.

Par défaut: faux

3 --codeCoverageExclude Globs à exclure de la couverture du code.
4 --configuration = configuration

Une cible de construction nommée, comme spécifié dans la section "configurations" de angular.json. Chaque cible nommée est accompagnée d'une configuration d'options par défaut pour cette cible. La définition de ceci remplace explicitement l'indicateur "--prod"

Alias: -c

5 --help = true | false | json | JSON

Affiche un message d'aide pour cette commande dans la console.

Par défaut: faux

6 --comprendre

Globs de fichiers à inclure, par rapport à l'espace de travail ou à la racine du projet. Il y a 2 cas particuliers -

  • lorsqu'un chemin d'accès au répertoire est fourni, tous les fichiers de spécifications se terminant par ".spec. @ (ts | tsx)" seront inclus.

  • lorsqu'un chemin d'accès à un fichier est fourni et qu'un fichier de spécification correspondant existe, il sera inclus à la place.

sept --karmaConfig = karmaConfig Le nom du fichier de configuration Karma.
8 --main = principal Le nom du fichier de point d'entrée principal.
9 --sondage Activez et définissez la période d'interrogation de surveillance des fichiers en millisecondes.
dix --polyfills = polyfills Le nom du fichier polyfills.
11 --preserveSymlinks = true | false

N'utilisez pas le chemin réel lors de la résolution des modules.

Par défaut: faux

12 --prod = vrai | faux Abréviation de "--configuration = production". Lorsque true, définit la configuration de construction sur la cible de production. Par défaut, la cible de production est configurée dans la configuration de l'espace de travail de sorte que toutes les versions utilisent le regroupement, le tremblement d'arborescence limité et l'élimination limitée du code mort.
13 --progress = true | false Enregistrez la progression dans la console pendant la construction.
13 --progress = true | false Enregistrez la progression dans la console pendant la construction.
14 - reporters Reporters Karma à utiliser. Passé directement au coureur de karma.
15 --sourceMap = true | false

Cartes de source de sortie.

Par défaut: vrai

16 --tsConfig = tsConfig Le nom du fichier de configuration TypeScript.
17 --watch = vrai | faux Exécutez la compilation lorsque les fichiers changent.
18 --webWorkerTsConfig = webWorkerTsConfig Configuration TypeScript pour les modules Web Worker.

Commencez par passer à un projet angulaire mis à jour à l'aide de la commande ng build .

Exécutez maintenant la commande de test.

Exemple

\>Node\>TutorialsPoint> ng test
...
WARN: ''app-goals' is not a known element:
1. If 'app-goals' is an Angular component, then verify that it is part of this module.
2. If 'app-goals' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message.'
Chrome 83.0.4103 (Windows 7.0.0): Executed 0 of 4 SUCCESS (0 secs / 0 secs)
...
AppComponent should render title FAILED
   TypeError: Cannot read property 'textContent' of null
      at <Jasmine>
      at UserContext.<anonymous> (http://localhost:9876/_karma_webpack_/src/app/app.component.spec.ts:33:51)
            ...
Chrome 83.0.4103 (Windows 7.0.0): Executed 1 of 4 (1 FAILED) (0 secs / 0.203 secs)
...
Chrome 83.0.4103 (Windows 7.0.0): Executed 2 of 4 (1 FAILED) (0 secs / 0.221 secs)
...
Chrome 83.0.4103 (Windows 7.0.0): Executed 4 of 4 (1 FAILED) (0 secs / 0.244 sec
Chrome 83.0.4103 (Windows 7.0.0): Executed 4 of 4 (1 FAILED) (0.282 secs / 0.244
 secs)
TOTAL: 1 FAILED, 3 SUCCESS

Maintenant, pour corriger les échecs, mettez à jour app.component.spec.ts

app.component.spec.ts

import { TestBed, async } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { AppComponent } from './app.component';

describe('AppComponent', () => {
   beforeEach(async(() => {
      TestBed.configureTestingModule({
         imports: [
            RouterTestingModule
         ],
         declarations: [
            AppComponent
         ],
      }).compileComponents();
   }));

   it('should create the app', () => {
      const fixture = TestBed.createComponent(AppComponent);
      const app = fixture.componentInstance;
      expect(app).toBeTruthy();
   });
});

Exécutez maintenant la commande de test.

Exemple

\>Node\>TutorialsPoint> ng test
...
WARN: ''app-goals' is not a known element:
1. If 'app-goals' is an Angular component, then verify that it is part of this m
odule.
2. If 'app-goals' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@
NgModule.schemas' of this component to suppress this message.'
Chrome 83.0.4103 (Windows 7.0.0): Executed 1 of 2 SUCCESS (0 secs / 0.053 secs)
...
Chrome 83.0.4103 (Windows 7.0.0): Executed 2 of 2 SUCCESS (0.097 secs / 0.073 se
cs)
TOTAL: 2 SUCCESS

ng test ouvre également le navigateur et affiche l'état du test.