gpt4 book ai didi

javascript - 在 PhantomJS 上运行时 Karma 测试失败

转载 作者:行者123 更新时间:2023-11-28 05:22:55 26 4
gpt4 key购买 nike

有 Angular、JS 的单元测试实现。该测试不是我创建的。该测试是使用 Jasmine 构建的,并在 PhantomJS 上使用 Karma 运行。

问题是测试打开 Chrome,执行某些操作并关闭浏览器。现在我想更改此实现,不使用 Chrome,而是使用 PhantomJs,以便不打开浏览器。

karma.conf.js 文件如下所示:

  module.exports = function(config) {

var appBase = 'app/'; // transpiled app JS files
var appAssets ='/base/app/'; // component assets fetched by Angular's compiler

config.set({
basePath: '',
frameworks: ['jasmine'],
plugins: [
require('karma-jasmine'),
// require('karma-chrome-launcher'),
require('karma-htmlfile-reporter'),
require('karma-phantomjs-launcher')
],

customLaunchers: {
expletiveRedacted: {
base: 'PhantomJS',
options: {
windowName: 'my-window',
settings: {
webSecurityEnabled: false
},
},
flags: ['--load-images=true'],
debug: true
},

// phantomjsLauncher: {
// // Have phantomjs exit if a ResourceError is encountered (useful if karma exits without killing phantom)
// exitOnResourceError: true
// }
},

// 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',
'node_modules/systemjs/dist/system-polyfills.js',

// Polyfills
'node_modules/core-js/client/shim.js',

// Reflect and Zone.js
'node_modules/reflect-metadata/Reflect.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 },

// Angular 2 itself and the testing library
{pattern: 'node_modules/@angular/**/*.js', included: false, watched: false},
{pattern: 'node_modules/@angular/**/*.js.map', included: false, watched: false},

{pattern: 'systemjs.config.js', included: false, watched: false},
// 'karma-test-shim.js',
{pattern: "karma-test-shim.js", watched: false},

// transpiled application & spec code paths loaded via module imports
{pattern: appBase + '**/*.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},

// 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: 'node_modules/angular2-notifications/**/*.js', included: false, watched: false},
{pattern: 'node_modules/angular2-notifications/**/*.js.map', included: false, watched: false}
],

// proxied base paths for loading assets
proxies: {
// required for component assets fetched by Angular's compiler
"/app/": appAssets
},

exclude: [],
preprocessors: {},
reporters: ['progress', 'html'],

// HtmlReporter configuration
htmlReporter: {
// Open this file to see results in browser
outputFile: '_test-output/tests.html',

// Optional
pageTitle: 'Unit Tests',
subPageTitle: __dirname
},

port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['expletiveRedacted'],
singleRun: true
})
}

karma-test-shim.js 文件:

// /*global jasmine, __karma__, window*/
Error.stackTraceLimit = Infinity;
jasmine.DEFAULT_TIMEOUT_INTERVAL = 1000;

__karma__.loaded = function () {
};

function isJsFile(path) {
return path.slice(-3) == '.js';
}

function isSpecFile(path) {
return /\.spec\.js$/.test(path);
}

function isBuiltFile(path) {
var builtPath = '/base/app/';
return isJsFile(path) && (path.substr(0, builtPath.length) == builtPath);
}

var allSpecFiles = Object.keys(window.__karma__.files)
.filter(isSpecFile)
.filter(isBuiltFile);

System.config({
baseURL: '/base/app',
packageWithIndex: true // sadly, we can't use umd packages (yet?)
});

System.import('systemjs.config.js')
.then(() => Promise.all([
System.import('@angular/core/testing'),
System.import('@angular/platform-browser-dynamic/testing')
]))
.then((providers) => {
var coreTesting = providers[0];
var browserTesting = providers[1];
coreTesting.TestBed.initTestEnvironment(
browserTesting.BrowserDynamicTestingModule,
browserTesting.platformBrowserDynamicTesting());

})
.then(function () {
// Finally, load all spec files.
// This will run the tests directly.
return Promise.all(
allSpecFiles.map(function (moduleName) {
return System.import(moduleName);
}));
})
.then(__karma__.start, __karma__.error);

现在,当我运行测试时,我收到下一个异常:

> karma start karma.conf.js

03 11 2016 12:31:11.264:INFO [karma]: Karma v1.3.0 server started at http://localhost:9876/
03 11 2016 12:31:11.264:INFO [launcher]: Launching browser expletiveRedacted with unlimited concurrency
03 11 2016 12:31:11.275:INFO [launcher]: Starting browser PhantomJS
03 11 2016 12:31:11.708:INFO [phantomjs.launcher]: ACTION REQUIRED:
03 11 2016 12:31:11.709:INFO [phantomjs.launcher]:
03 11 2016 12:31:11.709:INFO [phantomjs.launcher]: Launch browser at
03 11 2016 12:31:11.709:INFO [phantomjs.launcher]: http://localhost:9000/webkit/inspector/inspector.html?page=2
03 11 2016 12:31:11.709:INFO [phantomjs.launcher]:
03 11 2016 12:31:11.709:INFO [phantomjs.launcher]: Waiting 15 seconds ...
03 11 2016 12:31:28.639:INFO [PhantomJS 2.1.1 (Windows 8 0.0.0)]: Connected on socket /#7v0Lf6-X3ckgi5xZAAAA with id 33327697
PhantomJS 2.1.1 (Windows 8 0.0.0) ERROR
SyntaxError: Unexpected token ')'
at karma-test-shim.js:31


npm ERR! Test failed. See above for more details.

第 31 行如下: .then(() => Promise.all([

我不太了解 Node.JS。您知道这个问题的原因是什么以及如何解决它吗?

最佳答案

SyntaxError: Unexpected token ')'
at karma-test-shim.js:31

Line 31 is the following : .then(() => Promise.all([

这很可能是您使用了箭头函数。 Chrome 中支持它,但 PhantomJS 可能不支持。只需将其更改为使用 function 即可

System.import('systemjs.config.js')
.then(function() {
return Promise.all([
System.import('@angular/core/testing'),
System.import('@angular/platform-browser-dynamic/testing')
])
})
.then(function(providers) {
...
})

关于javascript - 在 PhantomJS 上运行时 Karma 测试失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40399860/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com