X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=test%2Funit%2Fmanipulation.js;h=cbc0b7715f843aa69b4a0ac743fcaf2436265d97;hb=4424bda377336342ce04ab5299bf1ce624cdb7b1;hp=2fc6f18899886570c5caa9f62de2728bc17feaa8;hpb=88fc523c59465b28633de91f4c9e87b8364064b7;p=jquery.git diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js index 2fc6f18..cbc0b77 100644 --- a/test/unit/manipulation.js +++ b/test/unit/manipulation.js @@ -1,5 +1,8 @@ module("manipulation"); +// Ensure that an extended Array prototype doesn't break jQuery +Array.prototype.arrayProtoFn = function(arg) { throw("arrayProtoFn should not be called"); }; + var bareObj = function(value) { return value; }; var functionReturningObj = function(value) { return (function() { return value; }); }; @@ -37,16 +40,16 @@ test("text(Function)", function() { test("text(Function) with incoming value", function() { expect(2); - + var old = "This link has class=\"blog\": Simon Willison's Weblog"; - + jQuery('#sap').text(function(i, val) { equals( val, old, "Make sure the incoming value is correct." ); return "foobar"; }); - + equals( jQuery("#sap").text(), "foobar", 'Check for merged text of more then one element.' ); - + QUnit.reset(); }); @@ -240,7 +243,7 @@ var testAppend = function(valueObj) { ok( jQuery("#sap").append(valueObj( [] )), "Check for appending an empty array." ); ok( jQuery("#sap").append(valueObj( "" )), "Check for appending an empty string." ); ok( jQuery("#sap").append(valueObj( document.getElementsByTagName("foo") )), "Check for appending an empty nodelist." ); - + QUnit.reset(); jQuery("form").append(valueObj('')); jQuery("form input[name=radiotest]").each(function(){ @@ -322,18 +325,18 @@ test("append(Function)", function() { test("append(Function) with incoming value", function() { expect(12); - + var defaultText = 'Try them out:', old = jQuery("#first").html(); - + var result = jQuery('#first').append(function(i, val){ equals( val, old, "Make sure the incoming value is correct." ); return 'buga'; }); equals( result.text(), defaultText + 'buga', 'Check if text appending works' ); - + var select = jQuery('#select3'); old = select.html(); - + equals( select.append(function(i, val){ equals( val, old, "Make sure the incoming value is correct." ); return ''; @@ -342,7 +345,7 @@ test("append(Function) with incoming value", function() { QUnit.reset(); var expected = "This link has class=\"blog\": Simon Willison's WeblogTry them out:"; old = jQuery("#sap").html(); - + jQuery('#sap').append(function(i, val){ equals( val, old, "Make sure the incoming value is correct." ); return document.getElementById('first'); @@ -352,7 +355,7 @@ test("append(Function) with incoming value", function() { QUnit.reset(); expected = "This link has class=\"blog\": Simon Willison's WeblogTry them out:Yahoo"; old = jQuery("#sap").html(); - + jQuery('#sap').append(function(i, val){ equals( val, old, "Make sure the incoming value is correct." ); return [document.getElementById('first'), document.getElementById('yahoo')]; @@ -362,7 +365,7 @@ test("append(Function) with incoming value", function() { QUnit.reset(); expected = "This link has class=\"blog\": Simon Willison's WeblogYahooTry them out:"; old = jQuery("#sap").html(); - + jQuery('#sap').append(function(i, val){ equals( val, old, "Make sure the incoming value is correct." ); return jQuery("#yahoo, #first"); @@ -371,16 +374,58 @@ test("append(Function) with incoming value", function() { QUnit.reset(); old = jQuery("#sap").html(); - + jQuery("#sap").append(function(i, val){ equals( val, old, "Make sure the incoming value is correct." ); return 5; }); - ok( jQuery("#sap")[0].innerHTML.match( /5$/ ), "Check for appending a number" ); - + ok( jQuery("#sap")[0].innerHTML.match( /5$/ ), "Check for appending a number" ); + QUnit.reset(); }); +test("append the same fragment with events (Bug #6997, 5566)", function () { + expect(4 + (document.fireEvent ? 1 : 0)); + stop(1000); + + var element; + + // This patch modified the way that cloning occurs in IE; we need to make sure that + // native event handlers on the original object don't get disturbed when they are + // modified on the clone + if (!jQuery.support.noCloneEvent && document.fireEvent) { + element = jQuery("div:first").click(function () { + ok(true, "Event exists on original after being unbound on clone"); + jQuery(this).unbind('click'); + }); + element.clone(true).unbind('click')[0].fireEvent('onclick'); + element[0].fireEvent('onclick'); + } + + element = jQuery("").click(function () { + ok(true, "Append second element events work"); + }); + + jQuery("#listWithTabIndex li").append(element) + .find('a.test6997').eq(1).click(); + + element = jQuery("
  • ").click(function () { + ok(true, "Before second element events work"); + start(); + }); + + jQuery("#listWithTabIndex li").before(element); + jQuery("#listWithTabIndex li.test6997").eq(1).click(); + + element = jQuery(""); + + equals( element.clone().find("option:selected").val(), element.find("option:selected").val(), "Selected option cloned correctly" ); + + element = jQuery("").attr('checked', 'checked'); + + equals( element.clone().is(":checked"), element.is(":checked"), "Checked input cloned correctly" ); +}); + test("appendTo(String|Element|Array<Element>|jQuery)", function() { expect(16); @@ -489,16 +534,16 @@ test("prepend(Function)", function() { test("prepend(Function) with incoming value", function() { expect(10); - + var defaultText = 'Try them out:', old = jQuery('#first').html(); var result = jQuery('#first').prepend(function(i, val) { equals( val, old, "Make sure the incoming value is correct." ); return 'buga'; }); equals( result.text(), 'buga' + defaultText, 'Check if text prepending works' ); - + old = jQuery("#select3").html(); - + equals( jQuery('#select3').prepend(function(i, val) { equals( val, old, "Make sure the incoming value is correct." ); return ''; @@ -507,35 +552,35 @@ test("prepend(Function) with incoming value", function() { QUnit.reset(); var expected = "Try them out:This link has class=\"blog\": Simon Willison's Weblog"; old = jQuery('#sap').html(); - + jQuery('#sap').prepend(function(i, val) { equals( val, old, "Make sure the incoming value is correct." ); return document.getElementById('first'); }); - + equals( jQuery('#sap').text(), expected, "Check for prepending of element" ); QUnit.reset(); expected = "Try them out:YahooThis link has class=\"blog\": Simon Willison's Weblog"; old = jQuery('#sap').html(); - + jQuery('#sap').prepend(function(i, val) { equals( val, old, "Make sure the incoming value is correct." ); return [document.getElementById('first'), document.getElementById('yahoo')]; }); - + equals( jQuery('#sap').text(), expected, "Check for prepending of array of elements" ); QUnit.reset(); expected = "YahooTry them out:This link has class=\"blog\": Simon Willison's Weblog"; old = jQuery('#sap').html(); - + jQuery('#sap').prepend(function(i, val) { equals( val, old, "Make sure the incoming value is correct." ); return jQuery("#yahoo, #first"); }); - - equals( jQuery('#sap').text(), expected, "Check for prepending of jQuery object" ); + + equals( jQuery('#sap').text(), expected, "Check for prepending of jQuery object" ); }); test("prependTo(String|Element|Array<Element>|jQuery)", function() { @@ -680,7 +725,7 @@ test("insertAfter(String|Element|Array<Element>|jQuery)", function() { }); var testReplaceWith = function(val) { - expect(17); + expect(20); jQuery('#yahoo').replaceWith(val( 'buga' )); ok( jQuery("#replace")[0], 'Replace element with string' ); ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after string' ); @@ -748,6 +793,17 @@ var testReplaceWith = function(val) { //""); equals(jQuery('.replacewith').length, 1, 'Check number of elements in page.'); jQuery('.replacewith').remove(); + + QUnit.reset(); + + jQuery("#main").append("
    "); + equals( jQuery("#main").find("div[id=replaceWith]").length, 1, "Make sure only one div exists." ); + + jQuery("#replaceWith").replaceWith( val("
    ") ); + equals( jQuery("#main").find("div[id=replaceWith]").length, 1, "Make sure only one div exists." ); + + jQuery("#replaceWith").replaceWith( val("
    ") ); + equals( jQuery("#main").find("div[id=replaceWith]").length, 1, "Make sure only one div exists." ); } test("replaceWith(String|Element|Array<Element>|jQuery)", function() { @@ -757,7 +813,7 @@ test("replaceWith(String|Element|Array<Element>|jQuery)", function() { test("replaceWith(Function)", function() { testReplaceWith(functionReturningObj); - expect(18); + expect(21); var y = jQuery("#yahoo")[0]; @@ -803,7 +859,7 @@ test("replaceAll(String|Element|Array<Element>|jQuery)", function() { }); test("clone()", function() { - expect(31); + expect(36); equals( 'This is a normal link: Yahoo', jQuery('#en').text(), 'Assert text for #en' ); var clone = jQuery('#yahoo').clone(); equals( 'Try them out:Yahoo', jQuery('#first').append(clone).text(), 'Check for clone' ); @@ -817,7 +873,7 @@ test("clone()", function() { ]; for (var i = 0; i < cloneTags.length; i++) { var j = jQuery(cloneTags[i]); - equals( j[0].tagName, j.clone()[0].tagName, 'Clone a <' + cloneTags[i].substring(1)); + equals( j[0].tagName, j.clone()[0].tagName, 'Clone a ' + cloneTags[i]); } // using contents will get comments regular, text, and comment nodes @@ -843,11 +899,23 @@ test("clone()", function() { equals( div[0].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); div.find("table:last").trigger("click"); - div = jQuery("
    ").html(' '); + // this is technically an invalid object, but because of the special + // classid instantiation it is the only kind that IE has trouble with, + // so let's test with it too. + div = jQuery("
    ").html(' '); - div = div.clone(true); - equals( div.length, 1, "One element cloned" ); - equals( div[0].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); + clone = div.clone(true); + equals( clone.length, 1, "One element cloned" ); + equals( clone.html(), div.html(), "Element contents cloned" ); + equals( clone[0].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); + + // and here's a valid one. + div = jQuery("
    ").html(' '); + + clone = div.clone(true); + equals( clone.length, 1, "One element cloned" ); + equals( clone.html(), div.html(), "Element contents cloned" ); + equals( clone[0].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); div = jQuery("
    ").data({ a: true, b: true }); div = div.clone(true); @@ -861,6 +929,8 @@ test("clone()", function() { form.appendChild( div ); equals( jQuery(form).clone().children().length, 1, "Make sure we just get the form back." ); + + equal( jQuery("body").clone().children()[0].id, "qunit-header", "Make sure cloning body works" ); }); if (!isLocal) { @@ -955,18 +1025,29 @@ test("html(String)", function() { test("html(Function)", function() { testHtml(functionReturningObj); + + expect(33); + + QUnit.reset(); + + jQuery("#main").html(function(){ + return jQuery(this).text(); + }); + + ok( !/ 0, "Make sure text exists." ); }); test("html(Function) with incoming value", function() { expect(20); - + var div = jQuery("#main > div"), old = div.map(function(){ return jQuery(this).html() }); - + div.html(function(i, val) { equals( val, old[i], "Make sure the incoming value is correct." ); return "test"; }); - + var pass = true; div.each(function(){ if ( this.childNodes.length !== 1 ) { @@ -979,7 +1060,7 @@ test("html(Function) with incoming value", function() { // using contents will get comments regular, text, and comment nodes var j = jQuery("#nonnodes").contents(); old = j.map(function(){ return jQuery(this).html(); }); - + j.html(function(i, val) { equals( val, old[i], "Make sure the incoming value is correct." ); return "bold"; @@ -989,17 +1070,17 @@ test("html(Function) with incoming value", function() { if ( j.length === 2 ) { equals( null, null, "Make sure the incoming value is correct." ); } - + j.find('b').removeData(); equals( j.html().replace(/ xmlns="[^"]+"/g, "").toLowerCase(), "bold", "Check node,textnode,comment with html()" ); - + var $div = jQuery('
    '); - + equals( $div.html(function(i, val) { equals( val, "", "Make sure the incoming value is correct." ); return 5; }).html(), '5', 'Setting a number as html' ); - + equals( $div.html(function(i, val) { equals( val, "5", "Make sure the incoming value is correct." ); return 0; @@ -1010,16 +1091,16 @@ test("html(Function) with incoming value", function() { equals( val, "", "Make sure the incoming value is correct." ); return insert; }).html().replace(/>/g, ">"), insert, "Verify escaped insertion." ); - + equals( $div2.html(function(i, val) { equals( val.replace(/>/g, ">"), insert, "Make sure the incoming value is correct." ); return "x" + insert; }).html().replace(/>/g, ">"), "x" + insert, "Verify escaped insertion." ); - + equals( $div2.html(function(i, val) { equals( val.replace(/>/g, ">"), "x" + insert, "Make sure the incoming value is correct." ); return " " + insert; - }).html().replace(/>/g, ">"), " " + insert, "Verify escaped insertion." ); + }).html().replace(/>/g, ">"), " " + insert, "Verify escaped insertion." ); }); var testRemove = function(method) { @@ -1053,9 +1134,9 @@ var testRemove = function(method) { var count = 0; var first = jQuery("#ap").children(":first"); var cleanUp = first.click(function() { count++ })[method]().appendTo("body").click(); - + equals( method == "remove" ? 0 : 1, count ); - + cleanUp.detach(); }; @@ -1080,58 +1161,58 @@ test("empty()", function() { test("jQuery.cleanData", function() { expect(14); - + var type, pos, div, child; - + type = "remove"; - + // Should trigger 4 remove event div = getDiv().remove(); - + // Should both do nothing pos = "Outer"; div.trigger("click"); - + pos = "Inner"; div.children().trigger("click"); - + type = "empty"; div = getDiv(); child = div.children(); - + // Should trigger 2 remove event div.empty(); - + // Should trigger 1 pos = "Outer"; div.trigger("click"); - + // Should do nothing pos = "Inner"; child.trigger("click"); // Should trigger 2 div.remove(); - + type = "html"; - + div = getDiv(); child = div.children(); - + // Should trigger 2 remove event div.html("
    "); - + // Should trigger 1 pos = "Outer"; div.trigger("click"); - + // Should do nothing pos = "Inner"; child.trigger("click"); // Should trigger 2 div.remove(); - + function getDiv() { var div = jQuery("
    ").click(function(){ ok( true, type + " " + pos + " Click event fired." ); @@ -1142,15 +1223,15 @@ test("jQuery.cleanData", function() { }).focus(function(){ ok( false, type + " " + pos + " Focus event fired." ); }).end().appendTo("body"); - + div[0].detachEvent = div[0].removeEventListener = function(t){ ok( true, type + " Outer " + t + " event unbound" ); }; - + div[0].firstChild.detachEvent = div[0].firstChild.removeEventListener = function(t){ ok( true, type + " Inner " + t + " event unbound" ); }; - + return div; } });