kann nicht geladen werden angular.js für unit-Tests mit karma, jasmine, phantomjs, und maven
Ich versuche mich zu ordnen, meine Buchstabensuppe eckige, karma, jasmine, phantomjs, und maven. Ich Tue dies mit einem Spielzeug-Projekt für jetzt, in der Vorbereitung für die Integration in ein reales Projekt.
Das folgende ist meine Liste der relevanten Dateien:
./pom.xml
./src/main/webapp/index.html
./src/main/webapp/js/blog.js
./src/test/webapp/js/blogSpec.js
./src/test/webapp/js/karma.conf.js
./src/test/webapp/js/libs/angular-mocks.js
./src/test/webapp/js/libs/angular.js
Hier ist meine komplette pom:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.att.cdits</groupId>
<artifactId>angularjsexp</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<build>
<plugins>
<plugin>
<groupId>com.kelveden</groupId>
<artifactId>maven-karma-plugin</artifactId>
<version>1.5</version>
<executions>
<execution>
<goals>
<goal>start</goal>
</goals>
</execution>
</executions>
<configuration>
<configFile>${basedir}/src/test/webapp/js/karma.conf.js</configFile>
<browsers>PhantomJS</browsers>
<reporters>dots</reporters>
<colors>false</colors>
<autoWatch>false</autoWatch>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>com.kelveden</groupId>
<artifactId>maven-karma-plugin</artifactId>
<version>1.5</version>
</dependency>
</dependencies>
</project>
Und mein "karma.conf.js" Datei:
module.exports = function(config) {
config.set({
basePath: '',
frameworks: ['jasmine'],
files: [
"../../../../src/test/webapp/js/libs/*.js",
"../../../../src/main/webapp/js/*.js",
"../../../../src/test/webapp/js/*.js"
],
exclude: [],
reporters: ['dots'],
port: 9876,
colors: false,
logLevel: config.LOG_DEBUG,
autoWatch: false,
browsers: ['PhantomJS'],
captureTimeout: 60000,
singleRun: true
});
};
Das folgende ist ein Auszug aus meiner "mvn install" - Ausgabe, beginnend bei der Surefire Ausführung:
[INFO] --- maven-surefire-plugin:2.10:test (default-test) @ angularjsexp ---
[INFO] Surefire report directory: myhome\workspace6\angularjsexp\target\surefire-reports
-------------------------------------------------------
T E S T S
-------------------------------------------------------
Results :
Tests run: 0, Failures: 0, Errors: 0, Skipped: 0
[INFO]
[INFO] --- maven-karma-plugin:1.5:start (default) @ angularjsexp ---
cmd /C karma start myhome\workspace6\angularjsexp\src\test\webapp\js\karma.conf.js --browsers PhantomJS --reporters dots --single-run --no-auto-watch --colors false
DEBUG [plugin]: Loading karma-* from myhome\AppData\Roaming\npm\node_modules
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-chrome-launcher.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-coffee-preprocessor.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-firefox-launcher.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-html2js-preprocessor.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-jasmine.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-phantomjs-launcher.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-requirejs.
DEBUG [plugin]: Loading plugin myhome\AppData\Roaming\npm\node_modules/karma-script-launcher.
DEBUG [plugin]: Loading inlined plugin (defining ).
INFO [karma]: Karma v0.10.2 server started at http://localhost:9876/
INFO [launcher]: Starting browser PhantomJS
DEBUG [launcher]: Creating temp dir at C:\Cygwin\tmp\karma-77302282
DEBUG [launcher]: myhome\AppData\Roaming\npm\node_modules\karma-phantomjs-launcher\node_modules\phantomjs\lib\phantom\phantomjs.exe C:\Cygwin\tmp\karma-77302282/capture.js
DEBUG [watcher]: Excluded file "myhome/workspace6/angularjsexp/src/test/webapp/js/karma.conf.js"
DEBUG [watcher]: Resolved files:
myhome/AppData/Roaming/npm/node_modules/karma-jasmine/lib/jasmine.js
myhome/AppData/Roaming/npm/node_modules/karma-jasmine/lib/adapter.js
myhome/workspace6/angularjsexp/src/test/webapp/js/libs/angular-mocks.js
myhome/workspace6/angularjsexp/src/test/webapp/js/libs/angular.js
myhome/workspace6/angularjsexp/src/main/webapp/js/blog.js
myhome/workspace6/angularjsexp/src/main/webapp/js/checkbox-array.js
myhome/workspace6/angularjsexp/src/main/webapp/js/my-include.js
myhome/workspace6/angularjsexp/src/test/webapp/js/blogSpec.js
DEBUG [web-server]: serving: myhome\AppData\Roaming\npm\node_modules\karma\static/client.html
DEBUG [web-server]: serving: myhome\AppData\Roaming\npm\node_modules\karma\static/karma.js
DEBUG [karma]: A browser has connected on socket LI1NDCsuY-0i0Uxwkhs_
INFO [PhantomJS 1.9.2 (Windows 7)]: Connected on socket LI1NDCsuY-0i0Uxwkhs_
DEBUG [karma]: All browsers are ready, executing
DEBUG [web-server]: serving: myhome\AppData\Roaming\npm\node_modules\karma\static/context.html
DEBUG [web-server]: serving: myhome/AppData/Roaming/npm/node_modules/karma-jasmine/lib/adapter.js
DEBUG [web-server]: serving: myhome/AppData/Roaming/npm/node_modules/karma-jasmine/lib/jasmine.js
DEBUG [web-server]: serving: myhome/workspace6/angularjsexp/src/test/webapp/js/libs/angular.js
DEBUG [web-server]: serving: myhome/workspace6/angularjsexp/src/main/webapp/js/checkbox-array.js
DEBUG [web-server]: serving: myhome/workspace6/angularjsexp/src/main/webapp/js/blog.js
DEBUG [web-server]: serving: myhome/workspace6/angularjsexp/src/main/webapp/js/my-include.js
DEBUG [web-server]: serving: myhome/workspace6/angularjsexp/src/test/webapp/js/blogSpec.js
DEBUG [web-server]: serving: myhome/workspace6/angularjsexp/src/test/webapp/js/libs/angular-mocks.js
PhantomJS 1.9.2 (Windows 7) ERROR
ReferenceError: Can't find variable: angular
at myhome/workspace6/angularjsexp/src/test/webapp/js/libs/angular-mocks.js:16
PhantomJS 1.9.2 (Windows 7) ERROR
ReferenceError: Can't find variable: myApp
at myhome/workspace6/angularjsexp/src/main/webapp/js/checkbox-array.js:1
PhantomJS 1.9.2 (Windows 7) ERROR
ReferenceError: Can't find variable: myApp
at myhome/workspace6/angularjsexp/src/main/webapp/js/my-include.js:1
PhantomJS 1.9.2 (Windows 7) ERROR
ReferenceError: Can't find variable: module
at myhome/workspace6/angularjsexp/src/test/webapp/js/blogSpec.js:5
PhantomJS 1.9.2 (Windows 7): Executed 0 of 0 ERROR (0.273 secs /0 secs)
Ich habe die folgenden Fragen so weit, einige ärgernisse, einige Blocker:
* Es ist seltsam, dass das karma auflöst Datei-Pfad-Verweise relativ, wo es gefunden meine conf Datei, die ich wünschte, ich könnte das überschreiben.
* Es scheint, dass Surefire feuert, bevor das Karma. Ist es möglich zu integrieren?
* Meine Referenzen zu "eckig" und andere Objekte in meine Skripte sind offensichtlich versagt. Ich verstehe nicht, wie diese zu lösen.
InformationsquelleAutor David M. Karr | 2013-10-01
Du musst angemeldet sein, um einen Kommentar abzugeben.
Dank jemand auf die karma-Benutzer-Diskussionsgruppe, entdeckte ich, dass die geladenen Dateien aus dem "files" geladen werden müssen in der richtigen Reihenfolge. Zum Beispiel, anstelle von "
../../../../src/test/webapp/js/libs/*.js
", muss ich angeben "../../../../src/test/webapp/js/libs/angular.js
", dann "../../../../src/test/webapp/js/libs/angular-mocks.js
".Ich noch herausfinden, wie man richtig zu integrieren, Surefire, aber ich werde bitten, dass getrennt.
InformationsquelleAutor David M. Karr
Habe ich getestet, Eckig mit Karma und Jasmine und endlich hat es funktioniert! Mein Beispiel ist viel einfacher als deine, aber vielleicht kann es dir helfen. Ich habe eine Anwendung in Winkel in zwei Dateien:
controllers.js
application.js
Und die folgenden Dateien für Eckige:
angular.js
angular-mocks.js
angular-route.js
Habe ich bearbeitet die
karma.config.js
manuell und ich habe Dateien anstelle der Routen, weil es funktioniert auf eine konkrete Bestellung, so dass endlich die bestellte Datei-Liste für das Karma ist:Meine Verzeichnisstruktur ist:
Und ich test Karma in den root-Ordner mit
$ karma start karma.config.js
.Hoffe, das hilft
InformationsquelleAutor Timbergus