ndo*_*hoe 6 karma-runner karma-jasmine
在运行测试时,karma似乎多次复制最后一次测试,测试重复的次数似乎取决于测试的数量和用于运行的浏览器.
如果仅使用一个浏览器(PhantomJS或Chrome)进行一次测试,则测试会显示两次,当使用两种浏览器时,相同的单次测试最多显示6次.
我已经将测试记录添加到测试中,每个浏览器每次测试都会记录一次,因此测试运行的次数可能正确,但只是重复显示的结果.
karma.conf.js
module.exports = function(config) {
config.set({
// base path that will be used to resolve all patterns (eg. files, exclude)
basePath: '',
// frameworks to use
// available frameworks: https://npmjs.org/browse/keyword/karma-adapter
frameworks: ['jasmine'],
// list of files / patterns to load in the browser
files: [
'_test/test.js'
],
// list of files to exclude
exclude: [
],
// preprocess matching files before serving them to the browser
// available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
preprocessors: {
},
// test results reporter to use
// possible values: 'dots', 'progress'
// available reporters: https://npmjs.org/browse/keyword/karma-reporter
reporters: ['progress'],
// web server port
port: 9876,
// enable / disable colors in the output (reporters and logs)
colors: true,
// level of logging
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
logLevel: config.LOG_INFO,
// enable / disable watching file and executing tests whenever any file changes
autoWatch: true,
// start these browsers
// available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
browsers: ['PhantomJS', 'Chrome'],
// Continuous Integration mode
// if true, Karma captures browsers, runs the tests and exits
singleRun: false
})
}
Run Code Online (Sandbox Code Playgroud)
test.js
describe('karma testing', function () {
it('tests karma is working', function () {
expect(true).toBe(true);
console.log('test1');
});
});
Run Code Online (Sandbox Code Playgroud)
输出1浏览器(Chrome)
07 10 2015 16:41:14.890:INFO [karma]: Karma v0.13.10 server started at http://localhost:9876/
07 10 2015 16:41:14.897:INFO [launcher]: Starting browser Chrome
07 10 2015 16:41:16.364:INFO [Chrome 45.0.2454 (Windows 7 0.0.0)]: Connected on socket 0uvPocfSI0prGxwdAAAA with id 29520633
LOG: 'test1'
Chrome 45.0.2454 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0 secs / 0.003 secs
Chrome 45.0.2454 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.011 secs / 0.003 secs)
Run Code Online (Sandbox Code Playgroud)
输出2浏览器(PhantomJS,Chrome)
07 10 2015 16:27:31.399:INFO [karma]: Karma v0.13.10 server started at http://localhost:9876/
07 10 2015 16:27:31.407:INFO [launcher]: Starting browser PhantomJS
07 10 2015 16:27:31.420:INFO [launcher]: Starting browser Chrome
07 10 2015 16:27:32.886:INFO [PhantomJS 1.9.8 (Windows 7 0.0.0)]: Connected on socket P5focoe7004aPX1rAAAA with id 49258591
07 10 2015 16:27:33.077:INFO [Chrome 45.0.2454 (Windows 7 0.0.0)]: Connected on socket BGtRdqevRGGXZTA-AAAB with id 42323971
LOG: 'test1'
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0 secs / 0.003 secs)
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs / 0.003 s
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs / 0.003 s
Chrome 45.0.2454 (Windows 7 0.0.0) LOG: 'test1'
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs / 0.003 s
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs / 0.003 secs)
PhantomJS 1.9.8 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.007 secs / 0.003 secs)
Chrome 45.0.2454 (Windows 7 0.0.0): Executed 1 of 1 SUCCESS (0.028 secs / 0.002 secs)
TOTAL: 2 SUCCESS
Run Code Online (Sandbox Code Playgroud)
我已经安装了karma-cli并且没有安装了karma-cli,结果是相同的.
我已经查看了堆栈溢出和谷歌和一些人似乎遇到了类似的问题,但没有有意义的答案.
小智 1
当我尝试让美化器工作时,我遇到了类似的问题。
karma.conf 有几个选项,例如 autoWatch、浏览器、singleRun - 对吗?其中有一个称为 client 的属性。
客户端属性是一个具有自己的一些属性的对象。其目的是配置与测试客户端相关的设置,例如 Chrome。
客户端有一个名为 captureConsole 的属性。默认为 true,这意味着浏览器中的任何控制台日志记录也会发送回您的 bash。因此,默认情况下打开该功能后,我看到了 Chrome 的控制台日志记录和美化的点击输出。
在您的中尝试此设置,看看是否有帮助!
client: {
captureConsole: false
},
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1094 次 |
| 最近记录: |