Added test for #935
[jquery.git] / src / event / eventTest.js
index a71e01b..7fc91b0 100644 (file)
@@ -15,7 +15,7 @@ test("toggle(Function, Function) - add toggle event and fake a few clicks", func
 });
 
 test("unbind(event)", function() {
-       expect(4);
+       expect(6);
        var el = $("#firstp");
        el.click(function() {
                ok( true, "Fake normal bind" );
@@ -29,6 +29,13 @@ test("unbind(event)", function() {
        el.click(function() { return; });
        el.unbind('click');
        ok( !el[0].onclick, "Handler is removed" ); // Bug #964
+
+       el.click(function() { return; });
+       el.unbind('change',function(){ return; });
+       ok( el[0].onclick, "Extra handlers weren't accidentally removed." );
+
+       el.unbind('click');
+       ok( !el[0].$events, "Removed the events expando after all handlers are unbound." );
 });
 
 test("trigger(event, [data]", function() {
@@ -59,4 +66,42 @@ test("bind() with data and trigger() with data", function() {
                ok( data.bar == "foo", "Check value of trigger data" );
        }
        $("#firstp").bind("click", {foo: "bar"}, handler).trigger("click", [{bar: "foo"}]);
+});
+
+test("toggle(Function,Function) assigned from within one('xxx'), see #1054", function() {
+       expect(4);
+       var first = 0;
+       $("#simon1").one("click", function() {
+               ok( true, "Execute event only once" );
+               $(this).toggle(function() {
+                       ok( first++ == 0 );
+               }, function() {
+                       ok( first == 1 );
+               });
+               return false;
+       }).click().click().click();
+       ok( false, "Seems like this doesn't work (that is, it doesn't fail) when triggering the event programmatically" );
+});
+
+test("events don't work with iframes, see #939", function() {
+       expect(2);
+       var iframe = document.getElementById('iframe');
+    var doc = iframe.contentDocument;
+    doc.addEventListener('click', function() {
+       ok( true, "Event handling via DOM 2 methods" );
+    }, false);
+    $(doc).click(function() {
+       ok( true, "Event handling via jQuery's handler" );
+    }).click();
+});
+
+test("Event.data is a global event object", function() {
+       expect(3);
+       var counter = 0;
+       function selectOnChange(event) {
+               equals( event.data, counter++ );
+       }
+       $("select").each(function(i){
+               $(this).bind('change', i, selectOnChange);
+       }).trigger('change');
 });
\ No newline at end of file