diff options
author | Timmy Willison <timmywillisn@gmail.com> | 2013-08-15 14:15:49 -0400 |
---|---|---|
committer | Timmy Willison <timmywillisn@gmail.com> | 2013-08-15 15:49:49 -0400 |
commit | 217cbb7109b7a5bbacd3170e90607ca5972fc1cd (patch) | |
tree | 4deb7b42f248f7ea73398dc329584899b5573413 /test/jquery.js | |
parent | 144837afdfab98d6a9f753bc4ccc1feede410101 (diff) | |
download | jquery-217cbb7109b7a5bbacd3170e90607ca5972fc1cd.tar.gz jquery-217cbb7109b7a5bbacd3170e90607ca5972fc1cd.zip |
AMD-ify jQuery sourcegit s! Woo! Fixes #14113, #14163.
Conflicts:
Gruntfile.js
README.md
src/ajax.js
src/ajax/xhr.js
src/attributes.js
src/core.js
src/css.js
src/data.js
src/effects.js
src/event.js
src/manipulation.js
src/offset.js
src/selector-native.js
src/traversing.js
test/unit/core.js
test/unit/data.js
Diffstat (limited to 'test/jquery.js')
-rw-r--r-- | test/jquery.js | 82 |
1 files changed, 77 insertions, 5 deletions
diff --git a/test/jquery.js b/test/jquery.js index 93d1095cd..faebaaed0 100644 --- a/test/jquery.js +++ b/test/jquery.js @@ -1,5 +1,77 @@ -// Use the right jQuery source in iframe tests -document.write( "<script id='jquery-js' src='" + - parent.document.getElementById("jquery-js").src.replace( /^(?![^\/?#]+:)/, - parent.location.pathname.replace( /[^\/]$/, "$0/" ) ) + -"'><\x2Fscript>" ); +// Use the right jQuery source on the test page (and iframes) +(function() { + /* global loadTests: true, testSubproject: false */ + /* jshint eqeqeq: false */ + + var i, len, + // Parent is the current window if not an iframe, which is fine + src = /^(.*)test\//.exec( parent.location.pathname )[1], + QUnit = QUnit || parent.QUnit, + require = require || parent.require; + + // Config parameter to force basic code paths + QUnit.config.urlConfig.push({ + id: "basic", + label: "Bypass optimizations", + tooltip: "Force use of the most basic code by disabling native querySelectorAll; contains; compareDocumentPosition" + }); + if ( QUnit.urlParams.basic ) { + document.querySelectorAll = null; + document.documentElement.contains = null; + document.documentElement.compareDocumentPosition = null; + } + + // iFrames won't load AMD (the iframe tests synchronously expect jQuery to be there) + QUnit.config.urlConfig.push({ + id: "amd", + label: "Load with AMD", + tooltip: "Load the AMD jQuery file (and its dependencies)" + }); + if ( QUnit.urlParams.amd && parent == window ) { + require.config({ baseUrl: src }); + src = "src/jquery"; + // Include tests if specified + if ( typeof loadTests !== "undefined" ) { + QUnit.config.autostart = false; + require( [ src ], function() { + // Ensure load order (to preserve test numbers) + (function loadDep() { + var dep = loadTests.shift(); + if ( dep ) { + require( [ dep ], loadDep ); + } else { + // Subproject tests must be last because they replace our test fixture + testSubproject( "Sizzle", "../bower_components/sizzle/test/", /^unit\/.*\.js$/ ); + + QUnit.start(); + } + })(); + }); + } else { + require( [ src ] ); + } + return; + } + + // Config parameter to use minified jQuery + QUnit.config.urlConfig.push({ + id: "dev", + label: "Load unminified", + tooltip: "Load the development (unminified) jQuery file" + }); + if ( QUnit.urlParams.dev ) { + src += "dist/jquery.js"; + } else { + src += "dist/jquery.min.js"; + } + + // Load jQuery + document.write( "<script id='jquery-js' src='" + src + "'><\x2Fscript>" ); + + // Load tests synchronously if available + if ( typeof loadTests !== "undefined" ) { + for ( i = 0, len = loadTests.length; i < len; i++ ) { + document.write( "<script src='" + loadTests.shift() + "'><\x2Fscript>" ); + } + } +})(); |