diff options
author | Dave Reed <dareed@microsoft.com> | 2010-09-29 06:46:25 -0700 |
---|---|---|
committer | John Resig <jeresig@gmail.com> | 2010-09-29 06:46:25 -0700 |
commit | cb811c04b035eb2d652b0831e20ea1d3a4d9c448 (patch) | |
tree | ea5d766ad8f3dcc9b33adfd734d04e26ddf27d36 /test | |
parent | ec7ea3fba15379ebe8ddff5f6c99ec3faf8d6d17 (diff) | |
download | jquery-cb811c04b035eb2d652b0831e20ea1d3a4d9c448.tar.gz jquery-cb811c04b035eb2d652b0831e20ea1d3a4d9c448.zip |
Using data() on JavaScript objects sets fields directly on the object. Note that events are now a property of a function (to avoid JSON serialization - and only in the case of JavaScript objects, not DOM nodes). Fixes #6807.
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/data.js | 60 | ||||
-rw-r--r-- | test/unit/event.js | 8 |
2 files changed, 40 insertions, 28 deletions
diff --git a/test/unit/data.js b/test/unit/data.js index 77ee09979..2efa98424 100644 --- a/test/unit/data.js +++ b/test/unit/data.js @@ -1,27 +1,22 @@ module("data"); test("expando", function(){ - expect(7); + expect(6); equals("expando" in jQuery, true, "jQuery is exposing the expando"); var obj = {}; - jQuery.data(obj); - equals( jQuery.expando in obj, true, "jQuery.data adds an expando to the object" ); - equals( typeof obj[jQuery.expando], "function", "jQuery.data adds an expando to the object as a function" ); + equals( jQuery.data(obj), obj, "jQuery.data(obj) returns the object"); + equals( jQuery.expando in obj, false, "jQuery.data(obj) did not add an expando to the object" ); obj = {}; jQuery.data(obj, 'test'); - equals( jQuery.expando in obj, false, "jQuery.data did not add an expando to the object" ); + equals( jQuery.expando in obj, false, "jQuery.data(obj,key) did not add an expando to the object" ); obj = {}; jQuery.data(obj, "foo", "bar"); - equals( jQuery.expando in obj, true, "jQuery.data added an expando to the object" ); - - var id = obj[jQuery.expando](); - equals( id in jQuery.cache, false, "jQuery.data did not add an entry to jQuery.cache" ); - - equals( id.foo, "bar", "jQuery.data worked correctly" ); + equals( jQuery.expando in obj, false, "jQuery.data(obj,key,value) did not add an expando to the object" ); + equals( obj.foo, "bar", "jQuery.data(obj,key,value) sets fields directly on the object." ); }); test("jQuery.acceptData", function() { @@ -43,7 +38,7 @@ test("jQuery.acceptData", function() { }); test("jQuery.data", function() { - expect(13); + expect(12); var div = document.createElement("div"); ok( jQuery.data(div, "test") === undefined, "Check for no data exists" ); @@ -67,17 +62,15 @@ test("jQuery.data", function() { jQuery.data(div, "test3", "orig"); jQuery.data(div, { "test": "in", "test2": "in2" }); - equals( jQuery.data(div, "test"), "in", "Verify setting an object in data." ); - equals( jQuery.data(div, "test2"), "in2", "Verify setting an object in data." ); - equals( jQuery.data(div, "test3"), "orig", "Verify original not overwritten." ); + equals( jQuery.data(div, "test"), "in", "Verify setting an object in data" ); + equals( jQuery.data(div, "test2"), "in2", "Verify setting an object in data" ); + equals( jQuery.data(div, "test3"), "orig", "Verify original not overwritten" ); var obj = {}; jQuery.data( obj, "prop", true ); - ok( obj[ jQuery.expando ], "Data is being stored on the object." ); - ok( obj[ jQuery.expando ]().prop, "Data is being stored on the object." ); - - equals( jQuery.data( obj, "prop" ), true, "Make sure the right value is retrieved." ); + ok( obj.prop, "Data is being stored on the object" ); + equals( jQuery.data( obj, "prop" ), true, "Make sure the right value is retrieved" ); }); test(".data()", function() { @@ -95,7 +88,7 @@ test(".data()", function() { }) test(".data(String) and .data(String, Object)", function() { - expect(27); + expect(29); var parent = jQuery("<div><div></div></div>"), div = parent.children(); @@ -173,14 +166,16 @@ test(".data(String) and .data(String, Object)", function() { equals( div.data("test.bar"), "testroot", "Check for unmatched namespace" ); // #3748 - var $elem = jQuery({}); + var $elem = jQuery({exists:true}); equals( $elem.data('nothing'), undefined, "Non-existent data returns undefined"); equals( $elem.data('null',null).data('null'), null, "null's are preserved"); equals( $elem.data('emptyString','').data('emptyString'), '', "Empty strings are preserved"); equals( $elem.data('false',false).data('false'), false, "false's are preserved"); - + equals( $elem.data('exists'), true, "Existing data is returned" ); + // Clean up $elem.removeData(); + ok( jQuery.isEmptyObject( $elem[0] ), "removeData clears the object" ); }); test("data-* attributes", function() { @@ -268,21 +263,34 @@ test("data-* attributes", function() { }); test(".data(Object)", function() { - expect(2); + expect(4); var div = jQuery("<div/>"); div.data({ "test": "in", "test2": "in2" }); - equals( div.data("test"), "in", "Verify setting an object in data." ); - equals( div.data("test2"), "in2", "Verify setting an object in data." ); + equals( div.data("test"), "in", "Verify setting an object in data" ); + equals( div.data("test2"), "in2", "Verify setting an object in data" ); + + var obj = {test:"unset"}, + jqobj = jQuery(obj); + jqobj.data({ "test": "in", "test2": "in2" }); + equals( obj.test, "in", "Verify setting an object on an object extends the object" ); + equals( obj.test2, "in2", "Verify setting an object on an object extends the object" ); }); test("jQuery.removeData", function() { - expect(1); + expect(4); var div = jQuery("#foo")[0]; jQuery.data(div, "test", "testing"); jQuery.removeData(div, "test"); equals( jQuery.data(div, "test"), undefined, "Check removal of data" ); + + var obj = {}; + jQuery.data(obj, "test", "testing"); + equals( obj.test, "testing", "verify data on plain object"); + jQuery.removeData(obj, "test"); + equals( jQuery.data(obj, "test"), undefined, "Check removal of data on plain object" ); + equals( obj.test, undefined, "Check removal of data directly from plain object" ); }); test(".removeData()", function() { diff --git a/test/unit/event.js b/test/unit/event.js index 10751ccaa..b5e24c8e7 100644 --- a/test/unit/event.js +++ b/test/unit/event.js @@ -443,7 +443,7 @@ test("bind(name, false), unbind(name, false)", function() { }); test("bind()/trigger()/unbind() on plain object", function() { - expect( 2 ); + expect( 5 ); var obj = {}; @@ -457,7 +457,11 @@ test("bind()/trigger()/unbind() on plain object", function() { ok( true, "Custom event run." ); }); - ok( jQuery(obj).data("events"), "Object has events bound." ); + var events = jQuery(obj).data("events"); + ok( events, "Object has events bound." ); + equals( typeof events, "function", "'events' expando is a function on plain objects." ); + equals( obj.test, undefined, "Make sure that test event is not on the plain object." ); + equals( obj.handle, undefined, "Make sure that the event handler is not on the plain object." ); // Should trigger 1 jQuery(obj).trigger("test"); |