From 607eeabfd28b59600c0dd7ff3234f7401bc4c5ba Mon Sep 17 00:00:00 2001 From: Manuel Friedli Date: Sun, 18 Jan 2015 21:49:19 +0100 Subject: [PATCH] use separate .jshintrc for the tests. this allows us to remove the "predef" section from the productive .jshintrc, which is good. --- .jshintrc | 12 ++-------- Gruntfile.js | 3 +++ test/.jshintrc | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 65 insertions(+), 10 deletions(-) create mode 100644 test/.jshintrc diff --git a/.jshintrc b/.jshintrc index 736c921..d285383 100644 --- a/.jshintrc +++ b/.jshintrc @@ -9,14 +9,6 @@ "node" : true, "jquery" : true, - "predef" : [ - "suite", - "test", - "define", - "require" - ], - - // Development. "debug" : false, // Allow debugger statements e.g. browser breakpoints. "devel" : true, // Allow developments statements e.g. `console.log();`. @@ -27,7 +19,7 @@ // The Good Parts. "asi" : false, // Tolerate Automatic Semicolon Insertion (no semicolons). - "laxbreak" : false, // Tolerate unsafe line breaks e.g. `return [\n] x` without semicolons. + "laxbreak" : false, // Tolerate unsafe line breaks e.g. `return [\n] x` without semicolons. "bitwise" : true, // Prohibit bitwise operators (&, |, ^, etc.). "boss" : false, // Tolerate assignments inside if, for & while. Usually conditions & loops are for comparison, not assignments. "curly" : true, // Require {} for every new block or scope. @@ -55,6 +47,6 @@ "plusplus" : false, // Prohibit use of `++` & `--`. "sub" : false, // Tolerate all forms of subscript notation besides dot notation e.g. `dict['key']` instead of `dict.key`. "trailing" : true, // Prohibit trailing whitespaces. - "white" : false, // Check against strict whitespace and indentation rules. + "white" : true, // Check against strict whitespace and indentation rules. "indent" : 0 // Specify indentation spacing } diff --git a/Gruntfile.js b/Gruntfile.js index 9841e32..69bb10e 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -107,6 +107,9 @@ module.exports = function (grunt) { src: ['src/**/*.js'] }, test: { + options: { + jshintrc: 'test/.jshintrc' + }, src: ['test/*.js'] } }, diff --git a/test/.jshintrc b/test/.jshintrc new file mode 100644 index 0000000..e53d084 --- /dev/null +++ b/test/.jshintrc @@ -0,0 +1,60 @@ +{ + // Settings + "passfail" : false, // Stop on first error. + "maxerr" : 100, // Maximum error before stopping. + + + // Predefined globals whom JSHint will ignore. + "browser" : true, // Standard browser globals e.g. `window`, `document`. + "node" : true, + "jquery" : true, + + "predef" : [ + "suite", + "chai", + "setup", + "teardown", + "test" + ], + + // Development. + "debug" : false, // Allow debugger statements e.g. browser breakpoints. + "devel" : true, // Allow developments statements e.g. `console.log();`. + + "strict" : true, // Require `use strict` pragma in every file. + "globalstrict" : false, // Allow global "use strict" (also enables 'strict'). + + + // The Good Parts. + "asi" : false, // Tolerate Automatic Semicolon Insertion (no semicolons). + "laxbreak" : false, // Tolerate unsafe line breaks e.g. `return [\n] x` without semicolons. + "bitwise" : true, // Prohibit bitwise operators (&, |, ^, etc.). + "boss" : false, // Tolerate assignments inside if, for & while. Usually conditions & loops are for comparison, not assignments. + "curly" : true, // Require {} for every new block or scope. + "eqeqeq" : true, // Require triple equals i.e. `===`. + "eqnull" : false, // Tolerate use of `== null`. + "evil" : false, // Tolerate use of `eval`. + "expr" : false, // Tolerate `ExpressionStatement` as Programs. + "forin" : false, // Tolerate `for in` loops without `hasOwnPrototype`. + "immed" : true, // Require immediate invocations to be wrapped in parens e.g. `( function(){}() );` + "latedef" : true, // Prohipit variable use before definition. + "loopfunc" : false, // Allow functions to be defined within loops. + "noarg" : true, // Prohibit use of `arguments.caller` and `arguments.callee`. + "scripturl" : true, // Tolerate script-targeted URLs. + "shadow" : false, // Allows re-define variables later in code e.g. `var x=1; x=2;`. + "supernew" : false, // Tolerate `new function () { ... };` and `new Object;`. + "undef" : true, // Require all non-global variables be declared before they are used. + + + // Personal styling preferences. + "newcap" : true, // Require capitalization of all constructor functions e.g. `new F()`. + "noempty" : true, // Prohibit use of empty blocks. + "nonew" : true, // Prohibit use of constructors for side-effects. + "nomen" : true, // Prohibit use of initial or trailing underbars in names. + "onevar" : false, // Allow only one `var` statement per function. + "plusplus" : false, // Prohibit use of `++` & `--`. + "sub" : false, // Tolerate all forms of subscript notation besides dot notation e.g. `dict['key']` instead of `dict.key`. + "trailing" : true, // Prohibit trailing whitespaces. + "white" : true, // Check against strict whitespace and indentation rules. + "indent" : 0 // Specify indentation spacing +}