-/*jshint node:true */
+/* eslint-env node */
+
module.exports = function ( grunt ) {
- grunt.loadNpmTasks( 'grunt-contrib-copy' );
- grunt.loadNpmTasks( 'grunt-contrib-jshint' );
- grunt.loadNpmTasks( 'grunt-stylelint' );
- grunt.loadNpmTasks( 'grunt-contrib-watch' );
- grunt.loadNpmTasks( 'grunt-banana-checker' );
- grunt.loadNpmTasks( 'grunt-jscs' );
- grunt.loadNpmTasks( 'grunt-jsonlint' );
- grunt.loadNpmTasks( 'grunt-karma' );
var wgServer = process.env.MW_SERVER,
wgScriptPath = process.env.MW_SCRIPT_PATH,
karmaProxy = {};
- karmaProxy[ wgScriptPath ] = wgServer + wgScriptPath;
+ grunt.loadNpmTasks( 'grunt-banana-checker' );
+ grunt.loadNpmTasks( 'grunt-contrib-copy' );
+ grunt.loadNpmTasks( 'grunt-contrib-watch' );
+ grunt.loadNpmTasks( 'grunt-eslint' );
+ grunt.loadNpmTasks( 'grunt-jsonlint' );
+ grunt.loadNpmTasks( 'grunt-karma' );
+ grunt.loadNpmTasks( 'grunt-stylelint' );
+
+ karmaProxy[ wgScriptPath ] = {
+ target: wgServer + wgScriptPath,
+ changeOrigin: true
+ };
grunt.initConfig( {
- jshint: {
- options: {
- jshintrc: true
- },
- all: '.'
- },
- jscs: {
- all: '.'
+ eslint: {
+ all: [
+ '**/*.js',
+ '!docs/**',
+ '!tests/**',
+ '!node_modules/**',
+ '!resources/lib/**',
+ '!resources/src/jquery.tipsy/**',
+ '!resources/src/jquery/jquery.farbtastic.js',
+ '!resources/src/mediawiki.libs/**',
+ '!vendor/**',
+ // Explicitly say "**/*.js" here in case of symlinks
+ '!extensions/**/*.js',
+ '!skins/**/*.js',
+ // Skip functions aren't even parseable
+ '!resources/src/dom-level2-skip.js',
+ '!resources/src/es5-skip.js',
+ '!resources/src/mediawiki.hidpi-skip.js'
+ ]
},
jsonlint: {
all: [
- '.jscsrc',
'**/*.json',
'!{docs/js,extensions,node_modules,skins,vendor}/**'
]
options: {
syntax: 'less'
},
- src: '{resources/src/*,mw-config/**}/*.{css,less}'
+ src: '{resources/src,mw-config}/**/*.{css,less}'
},
watch: {
files: [
- '.{stylelintrc,jscsrc,jshintignore,jshintrc}',
+ '.{stylelintrc,eslintrc.json}',
'**/*',
'!{docs,extensions,node_modules,skins,vendor}/**'
],
main: {
browsers: [ 'Chrome' ]
},
+ chromium: {
+ browsers: [ 'Chromium' ]
+ },
more: {
browsers: [ 'Chrome', 'Firefox' ]
}
return !!( process.env.MW_SERVER && process.env.MW_SCRIPT_PATH );
} );
- grunt.registerTask( 'lint', [ 'jshint', 'jscs', 'jsonlint', 'banana', 'stylelint' ] );
+ grunt.registerTask( 'lint', [ 'eslint', 'banana', 'stylelint' ] );
grunt.registerTask( 'qunit', [ 'assert-mw-env', 'karma:main' ] );
grunt.registerTask( 'test', [ 'lint' ] );