aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Methvin <dave.methvin@gmail.com>2012-10-19 21:59:33 -0400
committerDave Methvin <dave.methvin@gmail.com>2012-10-19 21:59:45 -0400
commit32051e97c1e77d0b678648832d090168b534841c (patch)
tree1e528746ab95f46a078a60b885aee118125dc430
parent3144163f61ea89855818fab597a2b5f1074d10c3 (diff)
downloadjquery-32051e97c1e77d0b678648832d090168b534841c.tar.gz
jquery-32051e97c1e77d0b678648832d090168b534841c.zip
Combine parseJSON tests and fix style.
We only care about the result of parseJSON so there's no reason to feature detect the entire test.
-rw-r--r--test/unit/core.js85
1 files changed, 14 insertions, 71 deletions
diff --git a/test/unit/core.js b/test/unit/core.js
index 6738fbeb9..2a9ce74e0 100644
--- a/test/unit/core.js
+++ b/test/unit/core.js
@@ -1148,34 +1148,27 @@ test("jQuery.parseHTML", function() {
});
test("jQuery.parseJSON", function(){
- expect(8);
+ expect( 9 );
+ equal( jQuery.parseJSON( null ), null, "Actual null returns null" );
+ equal( jQuery.isEmptyObject( jQuery.parseJSON("{}") ), true, "Empty object returns empty object" );
+ deepEqual( jQuery.parseJSON("{\"test\":1}"), { "test": 1 }, "Plain object parses" );
+ deepEqual( jQuery.parseJSON("\n{\"test\":1}"), { "test": 1 }, "Leading whitespaces are ignored." );
raises(function() {
jQuery.parseJSON();
- }, null, "parseJson now matches JSON.parse for empty input." );
- equal(jQuery.parseJSON( null ), null, "parseJson now matches JSON.parse on null input." );
+ }, null, "Undefined raises an error" );
raises( function() {
jQuery.parseJSON( "" );
- }, null, "parseJson now matches JSON.parse for empty strings." );
-
- deepEqual( jQuery.parseJSON("{}"), {}, "Plain object parsing." );
- deepEqual( jQuery.parseJSON("{\"test\":1}"), {"test":1}, "Plain object parsing." );
-
- deepEqual( jQuery.parseJSON("\n{\"test\":1}"), {"test":1}, "Make sure leading whitespaces are handled." );
-
- try {
+ }, null, "Empty string raises an error" );
+ raises(function() {
+ jQuery.parseJSON("''");
+ }, null, "Single-quoted string raises an error" );
+ raises(function() {
jQuery.parseJSON("{a:1}");
- ok( false, "Test malformed JSON string." );
- } catch( e ) {
- ok( true, "Test malformed JSON string." );
- }
-
- try {
+ }, null, "Unquoted property raises an error" );
+ raises(function() {
jQuery.parseJSON("{'a':1}");
- ok( false, "Test malformed JSON string." );
- } catch( e ) {
- ok( true, "Test malformed JSON string." );
- }
+ }, null, "Single-quoted property raises an error" );
});
test("jQuery.parseXML", 8, function(){
@@ -1350,53 +1343,3 @@ test("jQuery.camelCase()", function() {
equal( jQuery.camelCase( key ), val, "Converts: " + key + " => " + val );
});
});
-
-// Ensure our window.JSON matches behavior of the native one, if it exists
-if ( window.JSON ) {
- test( "JQuery.parseJSON() equivalence to JSON.parse", function() {
- expect( 10 );
-
- var jsonParse = window.JSON;
- window.JSON = null;
-
- raises(function() {
- jsonParse.parse("''");
- });
-
- raises(function() {
- jQuery.parseJSON("''");
- });
-
- raises(function() {
- jsonParse.parse("");
- });
-
- raises(function() {
- jQuery.parseJSON("");
- });
-
- raises(function() {
- jsonParse.parse({});
- });
-
- raises(function() {
- jQuery.parseJSON({});
- });
-
- var parsedValue = jsonParse.parse(null);
- equal( parsedValue, null, "parsed null" );
-
- parsedValue = jQuery.parseJSON(null);
- equal( parsedValue, null, "parsed null" );
-
- parsedValue = jsonParse.parse("{}");
- equal( (typeof parsedValue === "object"), true );
-
- parsedValue = jQuery.parseJSON("{}");
- equal( (typeof parsedValue === "object"), true );
-
-
- window.JSON = jsonParse;
- });
-}
-