I am using Karma Angular Mocha Chai
in my project. I am doing TDD
and would like to test my changes. I did a console.log
in my test.js file but karma console
does not show that. I'm not sure how to even enable that?
Here is my karma.config.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: ['mocha', 'chai'],
// list of files / patterns to load in the browser
files: [
'src/main/webapp/js/angular.js',
'src/main/webapp/js/angular-simple-logger.js',
'src/main/webapp/js/services/myservice-test.js',
'src/main/webapp/js/controllers/*.js',
'src/test/webapp/**/*.js'
],
// list of files to exclude
exclude: [
],
client : {
captureConsole : true
},
// 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: ['Chrome'],
// Continuous Integration mode
// if true, Karma captures browsers, runs the tests and exits
singleRun: false,
// Concurrency level
// how many browser should be started simultaneous
concurrency: Infinity
})
}
Here is my package.json
:
{
"name": "myapp",
"version": "0.0.1",
"description": "my App",
"main": "src/main/webapp/index.html",
"directories": {
"doc": "docs"
},
"scripts": {
"test": "node_modules/.bin/karma start karma.config.js"
},
"repository": {
"type": "git",
"url": ""
},
"author": "",
"license": "ISC",
"devDependencies": {
"chai": "^3.5.0",
"karma": "^0.13.22",
"karma-chai": "^0.1.0",
"karma-chrome-launcher": "^0.2.2",
"karma-mocha": "^0.2.2",
"mocha": "^2.4.5"
},
"dependencies": {
"angular": "^1.5.1",
"angular-mocks": "^1.5.1"
}
}
Add
browserConsoleLogOptions: {
level: 'log'
},
to your config.set. This is a new (karma 1.5.0, circa 2017-02-20) refinement of karma behavior. See further discussion here: https://github.com/karma-runner/karma/issues/2582