aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/ajax.js6
-rw-r--r--src/ajax/script.js2
-rw-r--r--test/data/ajax/content-type.php5
-rw-r--r--test/unit/ajax.js104
4 files changed, 112 insertions, 5 deletions
diff --git a/src/ajax.js b/src/ajax.js
index 157934ef1..efc413650 100644
--- a/src/ajax.js
+++ b/src/ajax.js
@@ -322,9 +322,9 @@ jQuery.extend( {
},
contents: {
- xml: /xml/,
- html: /html/,
- json: /json/
+ xml: /\bxml\b/,
+ html: /\bhtml/,
+ json: /\bjson\b/
},
responseFields: {
diff --git a/src/ajax/script.js b/src/ajax/script.js
index 3978ba46c..485ba397b 100644
--- a/src/ajax/script.js
+++ b/src/ajax/script.js
@@ -18,7 +18,7 @@ jQuery.ajaxSetup( {
"application/ecmascript, application/x-ecmascript"
},
contents: {
- script: /(?:java|ecma)script/
+ script: /\b(?:java|ecma)script\b/
},
converters: {
"text script": function( text ) {
diff --git a/test/data/ajax/content-type.php b/test/data/ajax/content-type.php
new file mode 100644
index 000000000..162e3636d
--- /dev/null
+++ b/test/data/ajax/content-type.php
@@ -0,0 +1,5 @@
+<?php
+ $type = $_REQUEST['content-type'];
+ header("Content-type: $type");
+ echo $_REQUEST['response']
+?>
diff --git a/test/unit/ajax.js b/test/unit/ajax.js
index 647958773..ec3e07613 100644
--- a/test/unit/ajax.js
+++ b/test/unit/ajax.js
@@ -1794,7 +1794,109 @@ QUnit.module( "ajax", {
}
);
-// //----------- jQuery.ajaxPrefilter()
+ ajaxTest( "gh-2587 - when content-type not xml, but looks like one", 1, function( assert ) {
+ return {
+ url: url( "data/ajax/content-type.php" ),
+ data: {
+ "content-type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
+ "response": "<test/>"
+ },
+ success: function( result ) {
+ assert.strictEqual(
+ typeof result,
+ "string",
+ "Should handle it as a string, not xml"
+ );
+ }
+ };
+ } );
+
+ ajaxTest( "gh-2587 - when content-type not xml, but looks like one", 1, function( assert ) {
+ return {
+ url: url( "data/ajax/content-type.php" ),
+ data: {
+ "content-type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
+ "response": "<test/>"
+ },
+ success: function( result ) {
+ assert.strictEqual(
+ typeof result,
+ "string",
+ "Should handle it as a string, not xml"
+ );
+ }
+ };
+ } );
+
+ ajaxTest( "gh-2587 - when content-type not json, but looks like one", 1, function( assert ) {
+ return {
+ url: url( "data/ajax/content-type.php" ),
+ data: {
+ "content-type": "test/jsontest",
+ "response": JSON.stringify({test: "test"})
+ },
+ success: function( result ) {
+ assert.strictEqual(
+ typeof result,
+ "string",
+ "Should handle it as a string, not json"
+ );
+ }
+ };
+ } );
+
+ ajaxTest( "gh-2587 - when content-type not html, but looks like one", 1, function( assert ) {
+ return {
+ url: url( "data/ajax/content-type.php" ),
+ data: {
+ "content-type": "test/htmltest",
+ "response": "<p>test</p>"
+ },
+ success: function( result ) {
+ assert.strictEqual(
+ typeof result,
+ "string",
+ "Should handle it as a string, not html"
+ );
+ }
+ };
+ } );
+
+ ajaxTest( "gh-2587 - when content-type not javascript, but looks like one", 1, function( assert ) {
+ return {
+ url: url( "data/ajax/content-type.php" ),
+ data: {
+ "content-type": "test/testjavascript",
+ "response": "alert(1)"
+ },
+ success: function( result ) {
+ assert.strictEqual(
+ typeof result,
+ "string",
+ "Should handle it as a string, not javascript"
+ );
+ }
+ };
+ } );
+
+ ajaxTest( "gh-2587 - when content-type not ecmascript, but looks like one", 1, function( assert ) {
+ return {
+ url: url( "data/ajax/content-type.php" ),
+ data: {
+ "content-type": "test/testjavascript",
+ "response": "alert(1)"
+ },
+ success: function( result ) {
+ assert.strictEqual(
+ typeof result,
+ "string",
+ "Should handle it as a string, not ecmascript"
+ );
+ }
+ };
+ } );
+
+//----------- jQuery.ajaxPrefilter()
ajaxTest( "jQuery.ajaxPrefilter() - abort", 1, function( assert ) {
return {