aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorMichał Gołębiowski <m.goleb@gmail.com>2016-02-24 23:47:19 +0100
committerMichał Gołębiowski <m.goleb@gmail.com>2016-03-02 13:12:35 +0100
commit93a8fa6bfc1c8a469e188630b61e736dfb69e128 (patch)
tree47494be97e64818ae3f627c97530240f8f0d10a7 /test
parent8a91f8442f4d31bdd4b43035ee88d40fbb116f64 (diff)
downloadjquery-93a8fa6bfc1c8a469e188630b61e736dfb69e128.tar.gz
jquery-93a8fa6bfc1c8a469e188630b61e736dfb69e128.zip
Core: Deprecate jQuery.parseJSON
Fixes gh-2800 Closes gh-2948
Diffstat (limited to 'test')
-rw-r--r--test/unit/ajax.js2
-rw-r--r--test/unit/basic.js4
-rw-r--r--test/unit/core.js87
-rw-r--r--test/unit/data.js6
-rw-r--r--test/unit/deprecated.js72
5 files changed, 76 insertions, 95 deletions
diff --git a/test/unit/ajax.js b/test/unit/ajax.js
index 3e00afd4e..63f0edd9f 100644
--- a/test/unit/ajax.js
+++ b/test/unit/ajax.js
@@ -1120,7 +1120,7 @@ QUnit.module( "ajax", {
},
success: function( text ) {
assert.strictEqual( typeof text, "string", "json wasn't auto-determined" );
- var json = jQuery.parseJSON( text );
+ var json = JSON.parse( text );
assert.ok( json.length >= 2, "Check length" );
assert.strictEqual( json[ 0 ][ "name" ], "John", "Check JSON: first, name" );
assert.strictEqual( json[ 0 ][ "age" ], 21, "Check JSON: first, age" );
diff --git a/test/unit/basic.js b/test/unit/basic.js
index 49b518d3f..8a3d19ae6 100644
--- a/test/unit/basic.js
+++ b/test/unit/basic.js
@@ -76,7 +76,7 @@ QUnit.test( "show/hide", function( assert ) {
}
QUnit.test( "core", function( assert ) {
- assert.expect( 28 );
+ assert.expect( 27 );
var elem = jQuery( "<div></div><span></span>" );
@@ -135,8 +135,6 @@ QUnit.test( "core", function( assert ) {
assert.strictEqual( jQuery.parseHTML( "<div></div><span></span>" ).length,
2, "jQuery.parseHTML" );
-
- assert.deepEqual( jQuery.parseJSON( "{\"a\": 2}" ), { a: 2 }, "jQuery.parseJON" );
} );
QUnit.test( "data", function( assert ) {
diff --git a/test/unit/core.js b/test/unit/core.js
index accba6bd6..99b2acc45 100644
--- a/test/unit/core.js
+++ b/test/unit/core.js
@@ -1548,93 +1548,6 @@ if ( jQuery.support.createHTMLDocument ) {
} );
}
-QUnit.test( "jQuery.parseJSON", function( assert ) {
- assert.expect( 20 );
-
- assert.strictEqual( jQuery.parseJSON( null ), null, "primitive null" );
- assert.strictEqual( jQuery.parseJSON( "0.88" ), 0.88, "Number" );
- assert.strictEqual(
- jQuery.parseJSON( "\" \\\" \\\\ \\/ \\b \\f \\n \\r \\t \\u007E \\u263a \"" ),
- " \" \\ / \b \f \n \r \t ~ \u263A ",
- "String escapes"
- );
- assert.deepEqual( jQuery.parseJSON( "{}" ), {}, "Empty object" );
- assert.deepEqual( jQuery.parseJSON( "{\"test\":1}" ), { "test": 1 }, "Plain object" );
- assert.deepEqual( jQuery.parseJSON( "[0]" ), [ 0 ], "Simple array" );
-
- assert.deepEqual(
- jQuery.parseJSON( "[ \"string\", -4.2, 2.7180e0, 3.14E-1, {}, [], true, false, null ]" ),
- [ "string", -4.2, 2.718, 0.314, {}, [], true, false, null ],
- "Array of all data types"
- );
- assert.deepEqual(
- jQuery.parseJSON( "{ \"string\": \"\", \"number\": 4.2e+1, \"object\": {}," +
- "\"array\": [[]], \"boolean\": [ true, false ], \"null\": null }" ),
- { string: "", number: 42, object: {}, array: [ [] ], "boolean": [ true, false ], "null": null },
- "Dictionary of all data types"
- );
-
- assert.deepEqual( jQuery.parseJSON( "\n{\"test\":1}\t" ), { "test": 1 },
- "Leading and trailing whitespace are ignored" );
-
- assert.throws( function() {
- jQuery.parseJSON();
- }, null, "Undefined raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "" );
- }, null, "Empty string raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "''" );
- }, null, "Single-quoted string raises an error" );
- /*
-
- // Broken on IE8
- assert.throws(function() {
- jQuery.parseJSON("\" \\a \"");
- }, null, "Invalid string escape raises an error" );
-
- // Broken on IE8, Safari 5.1 Windows
- assert.throws(function() {
- jQuery.parseJSON("\"\t\"");
- }, null, "Unescaped control character raises an error" );
-
- // Broken on IE8
- assert.throws(function() {
- jQuery.parseJSON(".123");
- }, null, "Number with no integer component raises an error" );
-
- */
- assert.throws( function() {
- var result = jQuery.parseJSON( "0101" );
-
- // Support: IE9+
- // Ensure base-10 interpretation on browsers that erroneously accept leading-zero numbers
- if ( result === 101 ) {
- throw new Error( "close enough" );
- }
- }, null, "Leading-zero number raises an error or is parsed as decimal" );
- assert.throws( function() {
- jQuery.parseJSON( "{a:1}" );
- }, null, "Unquoted property raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "{'a':1}" );
- }, null, "Single-quoted property raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "[,]" );
- }, null, "Array element elision raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "{},[]" );
- }, null, "Comma expression raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "[]\n,{}" );
- }, null, "Newline-containing comma expression raises an error" );
- assert.throws( function() {
- jQuery.parseJSON( "\"\"\n\"\"" );
- }, null, "Automatic semicolon insertion raises an error" );
-
- assert.strictEqual( jQuery.parseJSON( [ 0 ] ), 0, "Input cast to string" );
-} );
-
QUnit.test( "jQuery.parseXML", function( assert ) {
assert.expect( 8 );
diff --git a/test/unit/data.js b/test/unit/data.js
index 31c6a6174..19f32504b 100644
--- a/test/unit/data.js
+++ b/test/unit/data.js
@@ -277,7 +277,7 @@ QUnit.test( "data-* attributes", function( assert ) {
var prop, i, l, metadata, elem,
obj, obj2, check, num, num2,
- parseJSON = jQuery.parseJSON,
+ parseJSON = JSON.parse,
div = jQuery( "<div>" ),
child = jQuery( "<div data-myobj='old data' data-ignored=\"DOM\" data-other='test' data-foo-42='boosh'></div>" ),
dummy = jQuery( "<div data-myobj='old data' data-ignored=\"DOM\" data-other='test' data-foo-42='boosh'></div>" );
@@ -336,7 +336,7 @@ QUnit.test( "data-* attributes", function( assert ) {
// attribute parsing
i = 0;
- jQuery.parseJSON = function() {
+ JSON.parse = function() {
i++;
return parseJSON.apply( this, arguments );
};
@@ -389,7 +389,7 @@ QUnit.test( "data-* attributes", function( assert ) {
assert.strictEqual( child.data( "string" ), "test", "Typical string read from attribute" );
assert.equal( i, 2, "Correct number of JSON parse attempts when reading from attributes" );
- jQuery.parseJSON = parseJSON;
+ JSON.parse = parseJSON;
child.remove();
// tests from metadata plugin
diff --git a/test/unit/deprecated.js b/test/unit/deprecated.js
index 797290f3b..baf4562b1 100644
--- a/test/unit/deprecated.js
+++ b/test/unit/deprecated.js
@@ -39,4 +39,74 @@ QUnit.test( "delegate/undelegate", function( assert ) {
.end()
.undelegate( "b", "click" )
.remove();
-} ); \ No newline at end of file
+} );
+
+QUnit.test( "jQuery.parseJSON", function( assert ) {
+ assert.expect( 20 );
+
+ assert.strictEqual( jQuery.parseJSON( null ), null, "primitive null" );
+ assert.strictEqual( jQuery.parseJSON( "0.88" ), 0.88, "Number" );
+ assert.strictEqual(
+ jQuery.parseJSON( "\" \\\" \\\\ \\/ \\b \\f \\n \\r \\t \\u007E \\u263a \"" ),
+ " \" \\ / \b \f \n \r \t ~ \u263A ",
+ "String escapes"
+ );
+ assert.deepEqual( jQuery.parseJSON( "{}" ), {}, "Empty object" );
+ assert.deepEqual( jQuery.parseJSON( "{\"test\":1}" ), { "test": 1 }, "Plain object" );
+ assert.deepEqual( jQuery.parseJSON( "[0]" ), [ 0 ], "Simple array" );
+
+ assert.deepEqual(
+ jQuery.parseJSON( "[ \"string\", -4.2, 2.7180e0, 3.14E-1, {}, [], true, false, null ]" ),
+ [ "string", -4.2, 2.718, 0.314, {}, [], true, false, null ],
+ "Array of all data types"
+ );
+ assert.deepEqual(
+ jQuery.parseJSON( "{ \"string\": \"\", \"number\": 4.2e+1, \"object\": {}," +
+ "\"array\": [[]], \"boolean\": [ true, false ], \"null\": null }" ),
+ { string: "", number: 42, object: {}, array: [ [] ], "boolean": [ true, false ], "null": null },
+ "Dictionary of all data types"
+ );
+
+ assert.deepEqual( jQuery.parseJSON( "\n{\"test\":1}\t" ), { "test": 1 },
+ "Leading and trailing whitespace are ignored" );
+
+ assert.throws( function() {
+ jQuery.parseJSON();
+ }, null, "Undefined raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "" );
+ }, null, "Empty string raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "''" );
+ }, null, "Single-quoted string raises an error" );
+
+ assert.throws( function() {
+ var result = jQuery.parseJSON( "0101" );
+
+ // Support: IE9+
+ // Ensure base-10 interpretation on browsers that erroneously accept leading-zero numbers
+ if ( result === 101 ) {
+ throw new Error( "close enough" );
+ }
+ }, null, "Leading-zero number raises an error or is parsed as decimal" );
+ assert.throws( function() {
+ jQuery.parseJSON( "{a:1}" );
+ }, null, "Unquoted property raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "{'a':1}" );
+ }, null, "Single-quoted property raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "[,]" );
+ }, null, "Array element elision raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "{},[]" );
+ }, null, "Comma expression raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "[]\n,{}" );
+ }, null, "Newline-containing comma expression raises an error" );
+ assert.throws( function() {
+ jQuery.parseJSON( "\"\"\n\"\"" );
+ }, null, "Automatic semicolon insertion raises an error" );
+
+ assert.strictEqual( jQuery.parseJSON( [ 0 ] ), 0, "Input cast to string" );
+} );