Simplified a selector in the .live() tests.
[jquery.git] / test / unit / event.js
index d324432..65b08af 100644 (file)
@@ -45,6 +45,59 @@ test("bind(), no data", function() {
        jQuery("#firstp").bind("click", handler).trigger("click");
 });
 
+test("bind/one/unbind(Object)", function(){
+       expect(6);
+       
+       var clickCounter = 0, mouseoverCounter = 0;
+       function handler(event) {
+               if (event.type == "click")
+                       clickCounter++;
+               else if (event.type == "mouseover")
+                       mouseoverCounter++;
+       };
+       
+       function handlerWithData(event) {
+               if (event.type == "click")
+                       clickCounter += event.data;
+               else if (event.type == "mouseover")
+                       mouseoverCounter += event.data;
+       };
+       
+       function trigger(){
+               $elem.trigger("click").trigger("mouseover");
+       }
+       
+       var $elem = jQuery("#firstp")
+               // Regular bind
+               .bind({
+                       click:handler,
+                       mouseover:handler
+               })
+               // Bind with data
+               .one({
+                       click:handlerWithData,
+                       mouseover:handlerWithData
+               }, 2 );
+       
+       trigger();
+       
+       equals( clickCounter, 3, "bind(Object)" );
+       equals( mouseoverCounter, 3, "bind(Object)" );
+       
+       trigger();
+       equals( clickCounter, 4, "bind(Object)" );
+       equals( mouseoverCounter, 4, "bind(Object)" );
+       
+       jQuery("#firstp").unbind({
+               click:handler,
+               mouseover:handler
+       });
+
+       trigger();
+       equals( clickCounter, 4, "bind(Object)" );
+       equals( mouseoverCounter, 4, "bind(Object)" );
+});
+
 test("bind(), iframes", function() {
        // events don't work with iframes, see #939 - this test fails in IE because of contentDocument
        var doc = jQuery("#loadediframe").contents();
@@ -139,6 +192,10 @@ test("bind(), multi-namespaced events", function() {
        jQuery("#firstp").bind("click.test.abc",function(e){
                check("click.test.abc", "Namespaced click triggered");
        });
+       
+       // Those would not trigger/unbind (#5303)
+       jQuery("#firstp").trigger("click.a.test");
+       jQuery("#firstp").unbind("click.a.test");
 
        // Trigger both bound fn (1)
        jQuery("#firstp").trigger("click.test.abc");
@@ -337,7 +394,7 @@ test("trigger() bubbling", function() {
 });
 
 test("trigger(type, [data], [fn])", function() {
-       expect(11);
+       expect(12);
 
        var handler = function(event, a, b, c) {
                equals( event.type, "click", "check passed data" );
@@ -374,6 +431,14 @@ test("trigger(type, [data], [fn])", function() {
                pass = false;
        }
        ok( pass, "Trigger focus on hidden element" );
+       
+       pass = true;
+       try {
+               jQuery('table:first').bind('test:test', function(){}).trigger('test:test');
+       } catch (e) {
+               pass = false;
+       }
+       ok( pass, "Trigger on a table with a colon in the even type, see #3533" );
 });
 
 test("trigger(eventObject, [data], [fn])", function() {
@@ -471,7 +536,7 @@ test("jQuery.Event.currentTarget", function(){
 });
 
 test("toggle(Function, Function, ...)", function() {
-       expect(11);
+       expect(16);
        
        var count = 0,
                fn1 = function(e) { count++; },
@@ -524,6 +589,22 @@ test("toggle(Function, Function, ...)", function() {
        $div.unbind('click',fns[0]);
        var data = jQuery.data( $div[0], 'events' );
        ok( !data, "Unbinding one function from toggle unbinds them all");
+
+       // Test Multi-Toggles
+       var a = [], b = [];
+       $div = jQuery("<div/>");
+       $div.toggle(function(){ a.push(1); }, function(){ a.push(2); });
+       $div.click();
+       same( a, [1], "Check that a click worked." );
+
+       $div.toggle(function(){ b.push(1); }, function(){ b.push(2); });
+       $div.click();
+       same( a, [1,2], "Check that a click worked with a second toggle." );
+       same( b, [1], "Check that a click worked with a second toggle." );
+
+       $div.click();
+       same( a, [1,2,1], "Check that a click worked with a second toggle, second click." );
+       same( b, [1,2], "Check that a click worked with a second toggle, second click." );
 });
 
 test(".live()/.die()", function() {
@@ -712,15 +793,17 @@ test(".live()/.die()", function() {
 
        jQuery('span#liveSpan1 a').click();
        equals( lived, 1, "Verify that only one first handler occurred." );
-       equals( livee, 0, "Verify that second handler don't." );
+       equals( livee, 0, "Verify that second handler doesn't." );
 
        // and one pair in inverse
-       jQuery('#liveHandlerOrder span#liveSpan2').live('click', function(){ livee++; });
-       jQuery('#liveHandlerOrder span#liveSpan2 a').live('click', function(){ lived++; return false; });
+       jQuery('span#liveSpan2').live('click', function(){ livee++; });
+       jQuery('span#liveSpan2 a').live('click', function(){ lived++; return false; });
 
+       lived = 0;
+       livee = 0;
        jQuery('span#liveSpan2 a').click();
-       equals( lived, 2, "Verify that only one first handler occurred." );
-       equals( livee, 0, "Verify that second handler don't." );
+       equals( lived, 1, "Verify that only one first handler occurred." );
+       equals( livee, 0, "Verify that second handler doesn't." );
        
        // Cleanup
        jQuery("span#liveSpan1 a, span#liveSpan1, span#liveSpan2 a, span#liveSpan2").die("click");
@@ -737,6 +820,59 @@ test(".live()/.die()", function() {
        jQuery('span#liveSpan1').die('click');
 });
 
+test("live with submit", function() {
+       var count = 0;
+       
+       jQuery("#testForm").live("submit", function() {
+               count++;
+               return false;
+       });
+       
+       jQuery("#testForm input[name=sub1]")[0].click();
+       jQuery("#testForm input[name=T1]").trigger({type: "keypress", keyCode: 13});
+       
+       equals(2, count);
+       
+       jQuery("#testForm").die("submit");
+});
+
+test("live with focus/blur", function(){
+       expect(2);
+
+       // Setup
+       jQuery("<input type='text' id='livefb' />").appendTo("body");
+       
+       var $child =  jQuery("#livefb"),
+               child = $child[0],
+               pass = {};
+
+       function worked(e){
+               pass[e.type] = true;
+       }
+       
+       $child.live("focus", worked);
+       $child.live("blur", worked);
+       
+       // Test
+       child.focus();
+       if (pass.focus)
+               ok(true, "Test live() with focus event");
+       else
+               ok(true, "Cannot test focus because the window isn't focused");
+
+       child.blur();
+       if (pass.blur)
+               ok( true, "Test live() with blur event");
+       else
+               ok(true, "Cannot test blur because the window isn't focused");
+       
+       // Teardown
+       $child.die("focus", worked);
+       $child.die("blur", worked);
+       $child.remove();
+       window.scrollTo(0,0);
+});
+
 test("Non DOM element events", function() {
        expect(3);