私は、TypeScript/JavaScriptとAngular2の初心者です。私は、VSTSビルドパイプラインの一部として実行できるAngular2アプリケーション用のユニットテストフレームワークをセットアップしようとしています。アイデアは、Chromeの代わりにファントムジで単体テストを実行することです。Angular2 Karma Phantom-JS ZoneAwareError
Angular2クイックスタートプロジェクトをhttps://github.com/angular/quickstartにダウンロードし、カルマのテストランナーはChromeブラウザで罰金を科しました。私はここで指示に従って、ファントムを使ってクイックスタートテストを実行しました:How to configure Angular2 Quickstart to run phantomjs?。
「system-polyfills.js」の参照リファレンスが追加されましたが、カルマを実行する際にZoneAwareエラーが発生します。
私は私のkarma.conf.jsファイルは次のようになりますのWindows 10上で
だ:
module.exports = function(config) {
var appBase = 'src/'; // transpiled app JS and map files
var appSrcBase = appBase; // app source TS files
// Testing helpers (optional) are conventionally in a folder called `testing`
var testingBase = 'testing/'; // transpiled test JS and map files
var testingSrcBase = 'testing/'; // test source TS files
config.set({
basePath: '',
frameworks: ['jasmine'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-phantomjs-launcher'),
require('karma-jasmine-html-reporter')
],
client: {
builtPaths: [appBase, testingBase], // add more spec base paths as needed
clearContext: false // leave Jasmine Spec Runner output visible in browser
},
customLaunchers: {
// From the CLI. Not used here but interesting
// chrome setup for travis CI using chromium
Chrome_travis_ci: {
base: 'Chrome',
flags: ['--no-sandbox']
}
},
files: [
// System.js for module loading
'node_modules/systemjs/dist/system.src.js',
// Polyfills
'node_modules/core-js/client/shim.js',
// zone.js
'node_modules/zone.js/dist/zone.js',
'node_modules/zone.js/dist/long-stack-trace-zone.js',
'node_modules/zone.js/dist/proxy.js',
'node_modules/zone.js/dist/sync-test.js',
'node_modules/zone.js/dist/jasmine-patch.js',
'node_modules/zone.js/dist/async-test.js',
'node_modules/zone.js/dist/fake-async-test.js',
// RxJs
{ pattern: 'node_modules/rxjs/**/*.js', included: false, watched: false },
{ pattern: 'node_modules/rxjs/**/*.js.map', included: false, watched: false },
// Paths loaded via module imports:
// Angular itself
{ pattern: 'node_modules/@angular/**/*.js', included: false, watched: false },
{ pattern: 'node_modules/@angular/**/*.js.map', included: false, watched: false },
{ pattern: appBase + '/systemjs.config.js', included: false, watched: false },
{ pattern: appBase + '/systemjs.config.extras.js', included: false, watched: false },
'karma-test-shim.js', // optionally extend SystemJS mapping e.g., with barrels
// transpiled application & spec code paths loaded via module imports
{ pattern: appBase + '**/*.js', included: false, watched: true },
{ pattern: testingBase + '**/*.js', included: false, watched: true },
// Asset (HTML & CSS) paths loaded via Angular's component compiler
// (these paths need to be rewritten, see proxies section)
{ pattern: appBase + '**/*.html', included: false, watched: true },
{ pattern: appBase + '**/*.css', included: false, watched: true },
{pattern: 'node_modules/systemjs/dist/system-polyfills.js', included: false, watched: false},
// Paths for debugging with source maps in dev tools
{ pattern: appBase + '**/*.ts', included: false, watched: false },
{ pattern: appBase + '**/*.js.map', included: false, watched: false },
{ pattern: testingSrcBase + '**/*.ts', included: false, watched: false },
{ pattern: testingBase + '**/*.js.map', included: false, watched: false}
],
// Proxied base paths for loading assets
proxies: {
// required for modules fetched by SystemJS
'/base/src/node_modules/': '/base/node_modules/'
},
exclude: [],
preprocessors: {},
reporters: ['progress', 'kjhtml'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: false,
browsers: ['PhantomJS'],
// you can define custom flags
customLaunchers: {
'PhantomJS_custom': {
base: 'PhantomJS',
options: {
windowName: 'my-window',
settings: {
webSecurityEnabled: false
},
},
flags: ['--load-images=true'],
debug: false
}
},
phantomjsLauncher: {
// Have phantomjs exit if a ResourceError is encountered (useful if karma exits without killing phantom)
exitOnResourceError: true
},
singleRun: true
})
}
私のpackage.jsonは、次のようになります。
{
"name": "angular-quickstart",
"version": "1.0.0",
"description": "QuickStart package.json from the documentation, supplemented with testing support",
"scripts": {
"build": "tsc -p src/",
"build:watch": "tsc -p src/ -w",
"build:e2e": "tsc -p e2e/",
"serve": "lite-server -c=bs-config.json",
"serve:e2e": "lite-server -c=bs-config.e2e.json",
"prestart": "npm run build",
"start": "concurrently \"npm run build:watch\" \"npm run serve\"",
"pree2e": "npm run build:e2e",
"e2e": "concurrently \"npm run serve:e2e\" \"npm run protractor\" --kill-others --success first",
"preprotractor": "webdriver-manager update",
"protractor": "protractor protractor.config.js",
"pretest": "npm run build",
"test": "concurrently \"npm run build:watch\" \"karma start karma.conf.js\"",
"pretest:once": "npm run build",
"test:once": "karma start karma.conf.js --single-run",
"lint": "tslint ./src/**/*.ts -t verbose"
},
"keywords": [],
"author": "",
"license": "MIT",
"dependencies": {
"@angular/common": "~4.0.0",
"@angular/compiler": "~4.0.0",
"@angular/core": "~4.0.0",
"@angular/forms": "~4.0.0",
"@angular/http": "~4.0.0",
"@angular/platform-browser": "~4.0.0",
"@angular/platform-browser-dynamic": "~4.0.0",
"@angular/router": "~4.0.0",
"angular-in-memory-web-api": "~0.3.0",
"systemjs": "0.19.40",
"core-js": "^2.4.1",
"rxjs": "5.0.1",
"zone.js": "^0.8.4"
},
"devDependencies": {
"@types/jasmine": "2.5.36",
"@types/node": "^6.0.46",
"canonical-path": "0.0.2",
"concurrently": "^3.2.0",
"jasmine-core": "~2.4.1",
"karma": "^1.3.0",
"karma-chrome-launcher": "^2.0.0",
"karma-cli": "^1.0.1",
"karma-jasmine": "^1.0.2",
"karma-jasmine-html-reporter": "^0.2.2",
"karma-phantomjs-launcher": "^1.0.4",
"lite-server": "^2.2.2",
"lodash": "^4.16.4",
"phantomjs-prebuilt": "^2.1.14",
"protractor": "~4.0.14",
"rimraf": "^2.5.4",
"tslint": "^3.15.1",
"typescript": "~2.1.0"
},
"repository": {}
}
ときI npm test
または.\node_modules\.bin\karma start
を実行します。次の出力が表示されます。
04 04 2017 13:17:59.648:INFO [karma]: Karma v1.5.0 server started at http://0.0.0.0:9876/
04 04 2017 13:17:59.649:INFO [launcher]: Launching browser PhantomJS with unlimited concurrency
04 04 2017 13:17:59.680:INFO [launcher]: Starting browser PhantomJS
04 04 2017 13:18:05.398:INFO [PhantomJS 2.1.1 (Windows 8 0.0.0)]: Connected on socket RP6_gUObf8qGXHOgAAAA with id 50128128
PhantomJS 2.1.1 (Windows 8 0.0.0) ERROR
{
"line": 923,
"sourceURL": "node_modules/zone.js/dist/zone.js",
"stack": "[email protected]_modules/zone.js/dist/zone.js:923:28\[email protected]_modules/systemjs/dist/system.src.js:122:87\[email protected]_modules/systemjs/dist/system.src.js:687:25\nnode_modules/systemjs/dist/system.src.js:495:22\[email protected]_modules/zone.js/dist/zone.js:365:31\[email protected]_modules/zone.js/dist/zone.js:125:49\nnode_modules/zone.js/dist/zone.js:760:60\[email protected]_modules/zone.js/dist/zone.js:398:36\[email protected]_modules/zone.js/dist/zone.js:165:57\[email protected]_modules/zone.js/dist/zone.js:593:42\[email protected]_modules/core-js/client/shim.js:4005:30\nnode_modules/core-js/client/shim.js:4018:32\[email protected]_modules/core-js/client/shim.js:4373:12",
"originalStack": "[email protected]_modules/zone.js/dist/zone.js:923:28\[email protected]_modules/systemjs/dist/system.src.js:122:87\[email protected]_modules/systemjs/dist/system.src.js:687:25\nnode_modules/systemjs/dist/system.src.js:495:22\[email protected]_modules/zone.js/dist/zone.js:365:31\[email protected]_modules/zone.js/dist/zone.js:125:49\nnode_modules/zone.js/dist/zone.js:760:60\[email protected]_modules/zone.js/dist/zone.js:398:36\[email protected]_modules/zone.js/dist/zone.js:165:57\[email protected]_modules/zone.js/dist/zone.js:593:42\[email protected]_modules/core-js/client/shim.js:4005:30\nnode_modules/core-js/client/shim.js:4018:32\[email protected]_modules/core-js/client/shim.js:4373:12",
"zoneAwareStack": "[email protected]_modules/systemjs/dist/system.src.js:122:87 [<root>]\[email protected]_modules/systemjs/dist/system.src.js:687:25 [<root>]\nnode_modules/systemjs/dist/system.src.js:495:22 [<root>]\[email protected]_modules/zone.js/dist/zone.js:125:49 [<root> => <root>]\nnode_modules/zone.js/dist/zone.js:760:60 [<root>]\[email protected]_modules/zone.js/dist/zone.js:165:57 [<root> => <root>]\[email protected]_modules/zone.js/dist/zone.js:593:42 [<root>]\[email protected]_modules/core-js/client/shim.js:4005:30 [<root>]\nnode_modules/core-js/client/shim.js:4018:32 [<root>]\[email protected]_modules/core-js/client/shim.js:4373:12 [<root>]",
"originalErr": {
"stack": "[email protected][native code]\[email protected]_modules/systemjs/dist/system.src.js:1555:18\[email protected]_modules/systemjs/dist/system.src.js:4035:22\[email protected]_modules/systemjs/dist/system.src.js:3300:36\[email protected]_modules/systemjs/dist/system.src.js:3135:28\[email protected]_modules/systemjs/dist/system.src.js:3510:17\[email protected]_modules/systemjs/dist/system.src.js:766:32\[email protected]_modules/systemjs/dist/system.src.js:964:36\[email protected]_modules/systemjs/dist/system.src.js:623:11\[email protected]_modules/systemjs/dist/system.src.js:669:24\nnode_modules/systemjs/dist/system.src.js:485:30\[email protected]_modules/zone.js/dist/zone.js:365:31\[email protected]_modules/zone.js/dist/zone.js:125:49\nnode_modules/zone.js/dist/zone.js:760:60\[email protected]_modules/zone.js/dist/zone.js:398:36\[email protected]_modules/zone.js/dist/zone.js:165:57\[email protected]_modules/zone.js/dist/zone.js:593:42\[email protected]_modules/core-js/client/shim.js:4005:30\nnode_modules/core-js/client/shim.js:4018:32\[email protected]_modules/core-js/client/shim.js:4373:12",
"line": 1555,
"sourceURL": "node_modules/systemjs/dist/system.src.js"
},
"__zone_symbol__currentTask": {
"type": "microTask",
"state": "notScheduled",
"source": "Promise.then",
"zone": "<root>",
"cancelFn": null,
"runCount": 0
}
}
PhantomJS 2.1.1 (Windows 8 0.0.0) ERROR
{
"line": 923,
"sourceURL": "node_modules/zone.js/dist/zone.js",
"stack": "[email protected]_modules/zone.js/dist/zone.js:923:28\[email protected]_modules/systemjs/dist/system.src.js:122:87\[email protected]_modules/systemjs/dist/system.src.js:687:25\nnode_modules/systemjs/dist/system.src.js:495:22\[email protected]_modules/zone.js/dist/zone.js:365:31\[email protected]_modules/zone.js/dist/zone.js:125:49\nnode_modules/zone.js/dist/zone.js:760:60\[email protected]_modules/zone.js/dist/zone.js:398:36\[email protected]_modules/zone.js/dist/zone.js:165:57\[email protected]_modules/zone.js/dist/zone.js:593:42\[email protected]_modules/core-js/client/shim.js:4005:30\nnode_modules/core-js/client/shim.js:4018:32\[email protected]_modules/core-js/client/shim.js:4373:12",
"originalStack": "[email protected]_modules/zone.js/dist/zone.js:923:28\[email protected]_modules/systemjs/dist/system.src.js:122:87\[email protected]_modules/systemjs/dist/system.src.js:687:25\nnode_modules/systemjs/dist/system.src.js:495:22\[email protected]_modules/zone.js/dist/zone.js:365:31\[email protected]_modules/zone.js/dist/zone.js:125:49\nnode_modules/zone.js/dist/zone.js:760:60\[email protected]_modules/zone.js/dist/zone.js:398:36\[email protected]_modules/zone.js/dist/zone.js:165:57\[email protected]_modules/zone.js/dist/zone.js:593:42\[email protected]_modules/core-js/client/shim.js:4005:30\nnode_modules/core-js/client/shim.js:4018:32\[email protected]_modules/core-js/client/shim.js:4373:12",
"zoneAwareStack": "[email protected]_modules/systemjs/dist/system.src.js:122:87 [<root>]\[email protected]_modules/systemjs/dist/system.src.js:687:25 [<root>]\nnode_modules/systemjs/dist/system.src.js:495:22 [<root>]\[email protected]_modules/zone.js/dist/zone.js:125:49 [<root> => <root>]\nnode_modules/zone.js/dist/zone.js:760:60 [<root>]\[email protected]_modules/zone.js/dist/zone.js:165:57 [<root> => <root>]\[email protected]_modules/zone.js/dist/zone.js:593:42 [<root>]\[email protected]_modules/core-js/client/shim.js:4005:30 [<root>]\nnode_modules/core-js/client/shim.js:4018:32 [<root>]\[email protected]_modules/core-js/client/shim.js:4373:12 [<root>]",
"originalErr": {
"stack": "[email protected][native code]\[email protected]_modules/systemjs/dist/system.src.js:1555:18\[email protected]_modules/systemjs/dist/system.src.js:4035:22\[email protected]_modules/systemjs/dist/system.src.js:3300:36\[email protected]_modules/systemjs/dist/system.src.js:3135:28\[email protected]_modules/systemjs/dist/system.src.js:3510:17\[email protected]_modules/systemjs/dist/system.src.js:766:32\[email protected]_modules/systemjs/dist/system.src.js:964:36\[email protected]_modules/systemjs/dist/system.src.js:623:11\[email protected]_modules/systemjs/dist/system.src.js:669:24\nnode_modules/systemjs/dist/system.src.js:485:30\[email protected]_modules/zone.js/dist/zone.js:365:31\[email protected]_modules/zone.js/dist/zone.js:125:49\nnode_modules/zone.js/dist/zone.js:760:60\[email protected]_modules/zone.js/dist/zone.js:398:36\[email protected]_modules/zone.js/dist/zone.js:165:57\[email protected]_modules/zone.js/dist/zone.js:593:42\[email protected]_modules/core-js/client/shim.js:4005:30\nnode_modules/core-js/client/shim.js:4018:32\[email protected]_modules/core-js/client/shim.js:4373:12",
"line": 1555,
"sourceURL": "node_modules/systemjs/dist/system.src.js"
},
"__zone_symbol__currentTask": {
"type": "microTask",
"state": "notScheduled",
"source": "Promise.then",
"zone": "<root>",
"cancelFn": null,
"runCount": 0
}
}
ご協力いただければ幸いです!
:ここでの記録、 "ハッキング" systemjs-アンギュラloader.js使用するの
。 – nottinhill