Heim >Web-Frontend >js-Tutorial >Angular CLI für Unit-Tests und E2E-Tests

Angular CLI für Unit-Tests und E2E-Tests

php中世界最好的语言
php中世界最好的语言Original
2018-06-14 10:28:431679Durchsuche

Dieses Mal stelle ich Ihnen Angular CLI für Unit-Tests und E2E-Tests vor. Was sind die Vorsichtsmaßnahmen für Unit-Tests und E2E-Tests mit Angular CLI? Hier sind praktische Fälle.

Unit-Tests.

Angular CLI verwendet Karma für Unit-Tests.

Führen Sie zuerst ng test --help oder ng aus test -h Hilfe anzeigen.

Um den Test auszuführen, führen Sie einfach ng test aus. Es werden alle .spec.ts-Dateien im Projekt ausgeführt.

Und es werden auch Änderungen in den Dateien erkannt . Wenn sich die Datei ändert, wird der Test erneut ausgeführt.

Er sollte in einem separaten Terminalprozess ausgeführt werden.

Erstellen Sie zunächst ein Winkelprojekt mit Routing:

ng new sales --routing

Führen Sie nach dem Erstellen des Projekts direkt den Befehl test aus:

ng test

Eine Seite mit den Testergebnisdaten wird angezeigt.

I Ich werde unten noch ein paar weitere Komponenten und ein Admin-Modul hinzufügen:

ng g c person
ng g c order
ng g m admin --routing
ng g c admin/user
ng g c admin/email

Dann konfigurieren Sie das Routing. Das Wichtigste ist, diesen Effekt zu erzielen:

At Dieses Mal führe ich ng test erneut aus:

Obwohl das Programm ohne Probleme läuft, gibt es im Test immer noch ein Problem: router-outlet ist keine Winkelkomponente.

Sie können einen Blick auf die Spezifikationsliste werfen:

Zu diesem Zeitpunkt, da das Admin-Modul unabhängig läuft Beim Ausführen des Tests verweist das Modul nicht auf das Router-Modul, sodass der Router nicht erkannt werden kann.

Wie kann dieses Problem gelöst werden?

Öffnen Sie admin.component.spec. ts:

Füllen Sie diesen Satz aus, dann gibt es keine Fehler:

NO_ERRORS_SCHEMA weist Angular an, es zu ignorieren diese nicht erkannten Elemente oder Elementattribute.

  1. -- code-coverage -cc Code Coverage Report, dies ist standardmäßig nicht aktiviert, da die Geschwindigkeit der Berichtserstellung immer noch relativ langsam ist

  2. --Farbausgabeergebnisse in verschiedenen Farben ist standardmäßig aktiviert.

  3. --single-run -sr führt den Test aus, erkennt jedoch keine Dateiänderungen und ist standardmäßig nicht aktiviert

  4. --progress gibt den Testvorgang aus. Gehen Sie zur Konsole und es ist standardmäßig aktiviert

  5. --sourcemaps - sm Quellkarten generieren Es ist standardmäßig aktiviert

  6. --watch -w Führen Sie den Test einmal aus und erkennen Sie Änderungen. Standardmäßig aktiviert

ng test ist Führen Sie den Test aus. Wenn sich die Datei ändert, wird der Test erneut ausgeführt.

Verwenden Sie ng test -sr oder ng test -w false, um einen einzelnen Test auszuführen

Testcodeabdeckung:

ng test --cc-Bericht wird standardmäßig im Ordner /coverage generiert, kann jedoch durch Ändern der Eigenschaften in .angular-cli.json geändert werden. Nehmen Sie Änderungen vor.

Generieren Sie eine Codeabdeckung Melden Sie es wie folgt:

ng test -sr -cc

wird normalerweise mit dem Parameter -sr verwendet (führen Sie einen Test durch).

befindet sich dann in der Coverage-Datei des Projekts. Generieren Sie einige Dateien im Ordner:

Index.html direkt öffnen:

Sie können sehen, dass sie alle 100% sind. Das liegt daran, dass ich nicht geschrieben habe Beliebiger Code.

Dann habe ich etwas Code in die Benutzerkomponente eingefügt:

再运行一次 ng test --sr -cc:

可以看到这部分代码并没有覆盖到.

如果我把代码里到 canGetUsers改为true:

再次执行ng test --sr -cc

可以看到这次代码覆盖率变化了:

只有catch部分没有覆盖到.

我认为代码覆盖率这个内置功能是非常好的.

Debug单元测试.

首先执行ng test:

然后点击debug, 并打开开发者工具:

然后按cmd+p:

找到需要调试的文件:

设置断点:

然后在spec里面也设置一个断点:

最后点击浏览器的刷新按钮即可:

E2E测试的参数.

实际上angular cli是配合着protractor来进行这个测试的.

它的命令是 ng e2e.

常用的参数有:

  1. --config -c 指定配置文件 默认是 protractor.conf.js

  2. --element-explorer -ee 打开protractor的元素浏览器

  3. --serve -s 在随机的端口编译和serve 默认true

  4. --specs -sp 默认是执行所有的spec文件, 如果想执行某个spec就使用这个参数, 默认是all

  5. --webdriver-update -wu 尝试更新webdriver 默认true

通常执行下面机组命令参数组合即可:

ng e2e
ng e2e -ee

Debug E2E测试.

看一下项目:

配置文件protractor.conf.js已经配置好.

而测试文件是在e2e目录下.

看一下spec和po文件:

再看一下app.component.html里面的值:

应该是没问题的.

所以执行ng e2e:

测试通过, 但是浏览器闪了一下就关闭了.

如果我想debug e2e, 那么执行这个命令:

ng e2e -ee

由于我使用的是mac, 当前这个命令在mac上貌似确实有一个bug:

Wenn Sie diesen Befehl normal ausführen können, werden im Terminalfenster die Worte „Debugger hört auf xxx:“ angezeigt, und Sie können dann unten Variablen oder Ausdrücke eingeben, um deren Werte anzuzeigen ​​und fortfahren.

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website.

Empfohlene Lektüre:

Angular verwendet ng-click, um mehrere Parameter zu übergeben

So ermitteln Sie das Gleiten des Benutzers in H5 Touch Veranstaltungsleitung

Das obige ist der detaillierte Inhalt vonAngular CLI für Unit-Tests und E2E-Tests. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn