diff options
author | Michał Gołębiowski <m.goleb@gmail.com> | 2015-08-03 20:28:37 +0200 |
---|---|---|
committer | Michał Gołębiowski <m.goleb@gmail.com> | 2015-09-08 17:42:38 +0200 |
commit | dbb2daa8c3a458e3525d310440f4365548edc138 (patch) | |
tree | 6344f8e8bdc184a20e2f178e7c4151a783215d7e /Gruntfile.js | |
parent | f9ef427d355a8a2b531aed5d112dfa4f9692105c (diff) | |
download | jquery-dbb2daa8c3a458e3525d310440f4365548edc138.tar.gz jquery-dbb2daa8c3a458e3525d310440f4365548edc138.zip |
Build: Don't install jsdom 3 on Node.js 0.10 & 0.12 by default
jsdom 3 requires Python & Visual Studio on Windows which is a significant
barrier to contributors. Newer jsdom versions don't require pre-compiling
but work only on io.js. This commit installs the new jsdom everywhere (it
does install in old Node.js, it just won't work) and executes Node-related
tests only on newer Nodes or if a working jsdom version is installed. The
latter can be achieved by running the `old_jsdom` task.
Node.js is merging with io.js soon so this will become a smaller problem over
time.
One drawback is our Jenkins setup runs on Node 0.10 so it won't be running
Node tests anymore. We have Travis set up on io.js, though so all PRs
have those tests run. When the new LTS Node.js arrives (as it soon merges
with io.js) we should update our Jenkins infrastructure so that it runs on this
new version.
Fixes gh-2519
Closes gh-2526
Diffstat (limited to 'Gruntfile.js')
-rw-r--r-- | Gruntfile.js | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/Gruntfile.js b/Gruntfile.js index c05b42546..97289a0ac 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -14,7 +14,18 @@ module.exports = function( grunt ) { var fs = require( "fs" ), stripJSONComments = require( "strip-json-comments" ), gzip = require( "gzip-js" ), - srcHintOptions = readOptionalJSON( "src/.jshintrc" ); + srcHintOptions = readOptionalJSON( "src/.jshintrc" ), + newNode = !/^v0/.test( process.version ), + + // Allow to skip jsdom-related tests in Node.js < 1.0.0 + runJsdomTests = newNode || ( function() { + try { + require( "jsdom" ); + return true; + } catch ( e ) { + return false; + } + } )(); // The concatenated file won't pass onevar // But our modules can @@ -182,9 +193,14 @@ module.exports = function( grunt ) { grunt.registerTask( "lint", [ "jsonlint", "jshint", "jscs" ] ); - grunt.registerTask( "test_fast", [ "node_smoke_tests" ] ); + // Don't run Node-related tests in Node.js < 1.0.0 as they require an old + // jsdom version that needs compiling, making it harder for people to compile + // jQuery on Windows. (see gh-2519) + grunt.registerTask( "test_fast", runJsdomTests ? [ "node_smoke_tests" ] : [] ); - grunt.registerTask( "test", [ "test_fast", "promises_aplus_tests" ] ); + grunt.registerTask( "test", [ "test_fast" ].concat( + runJsdomTests ? [ "promises_aplus_tests" ] : [] + ) ); // Short list as a high frequency watch task grunt.registerTask( "dev", [ "build:*:*", "lint", "uglify", "remove_map_comment", "dist:*" ] ); |