Tests: Fix tests for not auto-executing scripts without dataType

Two issues are fixed in testing for responses with a script Content-Type not
getting auto-executed unless an explicit `dataType: "script"` is provided:
* the test is now using a correct "text/javascript" Content-Type; it was using
  "text/html" until now which doesn't really check if the fix works
* the Node.js based version of the tests didn't account for an empty `header`
  query string parameter

Closes gh-4824
Ref gh-2432
Ref gh-2588
Ref 39cdb8c9aa
This commit is contained in:
Michał Gołębiowski-Owczarek 2021-01-11 18:20:36 +01:00 committed by GitHub
parent 3bbbc11111
commit d38528b17a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 2 additions and 2 deletions

View File

@ -62,7 +62,7 @@ var mocks = {
script: function( req, resp ) { script: function( req, resp ) {
if ( req.query.header === "ecma" ) { if ( req.query.header === "ecma" ) {
resp.writeHead( 200, { "content-type": "application/ecmascript" } ); resp.writeHead( 200, { "content-type": "application/ecmascript" } );
} else if ( req.query.header ) { } else if ( "header" in req.query ) {
resp.writeHead( 200, { "content-type": "text/javascript" } ); resp.writeHead( 200, { "content-type": "text/javascript" } );
} else { } else {
resp.writeHead( 200, { "content-type": "text/html" } ); resp.writeHead( 200, { "content-type": "text/html" } );

View File

@ -118,7 +118,7 @@ QUnit.module( "ajax", {
return { return {
create: function( options ) { create: function( options ) {
options.crossDomain = true; options.crossDomain = true;
return jQuery.ajax( url( "mock.php?action=script" ), options ); return jQuery.ajax( url( "mock.php?action=script&header" ), options );
}, },
success: function() { success: function() {
assert.ok( true, "success" ); assert.ok( true, "success" );