// testWrapInner(functionReturningObj)
// })
+var testUnwrap = function() {
+ expect(9);
+
+ jQuery("body").append(' <div id="unwrap" style="display: none;"> <div id="unwrap1"> <span class="unwrap">a</span> <span class="unwrap">b</span> </div> <div id="unwrap2"> <span class="unwrap">c</span> <span class="unwrap">d</span> </div> <div id="unwrap3"> <b><span class="unwrap unwrap3">e</span></b> <b><span class="unwrap unwrap3">f</span></b> </div> </div>');
+
+ var abcd = jQuery('#unwrap1 > span, #unwrap2 > span').get(),
+ abcdef = jQuery('#unwrap span').get();
+
+ equals( jQuery('#unwrap1 span, #unwrap2 span:first').unwrap().length, 3, 'make #unwrap1 and #unwrap2 go away' );
+ same( jQuery('#unwrap > span').get(), abcd, 'all four spans should still exist' );
+
+ same( jQuery('#unwrap3 span').unwrap().get(), jQuery('#unwrap3 > span').get(), 'make all b in #unwrap3 go away' );
+
+ same( jQuery('#unwrap3 span').unwrap().get(), jQuery('#unwrap > span.unwrap3').get(), 'make #unwrap3 go away' );
+
+ same( jQuery('#unwrap').children().get(), abcdef, '#unwrap only contains 6 child spans' );
+
+ same( jQuery('#unwrap > span').unwrap().get(), jQuery('body > span.unwrap').get(), 'make the 6 spans become children of body' );
+
+ same( jQuery('body > span.unwrap').unwrap().get(), jQuery('body > span.unwrap').get(), 'can\'t unwrap children of body' );
+ same( jQuery('body > span.unwrap').unwrap().get(), abcdef, 'can\'t unwrap children of body' );
+
+ same( jQuery('body > span.unwrap').get(), abcdef, 'body contains 6 .unwrap child spans' );
+
+ jQuery('body > span.unwrap').remove();
+}
+
+test("unwrap()", function() {
+ testUnwrap();
+});
+
var testAppend = function(valueObj) {
expect(21);
var defaultText = 'Try them out:'
});
var testBefore = function(val) {
- expect(4);
+ expect(6);
var expected = 'This is a normal link: bugaYahoo';
jQuery('#yahoo').before(val( '<b>buga</b>' ));
equals( expected, jQuery('#en').text(), 'Insert String before' );
expected = "This is a normal link: diveintomarkTry them out:Yahoo";
jQuery('#yahoo').before(val( jQuery("#first, #mark") ));
equals( expected, jQuery('#en').text(), "Insert jQuery before" );
+
+ var set = jQuery("<div/>").before("<span>test</span>");
+ equals( set[0].nodeName.toLowerCase(), "span", "Insert the element before the disconnected node." );
+ equals( set.length, 2, "Insert the element before the disconnected node." );
}
test("before(String|Element|Array<Element>|jQuery)", function() {
});
var testAfter = function(val) {
- expect(4);
+ expect(6);
var expected = 'This is a normal link: Yahoobuga';
jQuery('#yahoo').after(val( '<b>buga</b>' ));
equals( expected, jQuery('#en').text(), 'Insert String after' );
expected = "This is a normal link: YahoodiveintomarkTry them out:";
jQuery('#yahoo').after(val( jQuery("#first, #mark") ));
equals( expected, jQuery('#en').text(), "Insert jQuery after" );
+
+ var set = jQuery("<div/>").after("<span>test</span>");
+ equals( set[1].nodeName.toLowerCase(), "span", "Insert the element after the disconnected node." );
+ equals( set.length, 2, "Insert the element after the disconnected node." );
};
test("after(String|Element|Array<Element>|jQuery)", function() {
});
var testReplaceWith = function(val) {
- expect(10);
+ expect(12);
jQuery('#yahoo').replaceWith(val( '<b id="replace">buga</b>' ));
ok( jQuery("#replace")[0], 'Replace element with string' );
ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after string' );
ok( jQuery("#first")[0], 'Replace element with set of elements' );
ok( jQuery("#mark")[0], 'Replace element with set of elements' );
ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after set of elements' );
+
+ var set = jQuery("<div/>").replaceWith(val("<span>test</span>"));
+ equals( set[0].nodeName.toLowerCase(), "span", "Replace the disconnected node." );
+ equals( set.length, 1, "Replace the disconnected node." );
}
test("replaceWith(String|Element|Array<Element>|jQuery)", function() {
equals( jQuery('#select2').val(), '3', 'Call val() on a single="single" select' );
- isSet( jQuery('#select3').val(), ['1', '2'], 'Call val() on a multiple="multiple" select' );
+ same( jQuery('#select3').val(), ['1', '2'], 'Call val() on a multiple="multiple" select' );
equals( jQuery('#option3c').val(), '2', 'Call val() on a option element with value' );
}
ok( pass, "Set HTML" );
- window.debug = false;
+ delete window.debug;
reset();
// using contents will get comments regular, text, and comment nodes
stop();
- jQuery("#main").html(valueObj('<script type="text/javascript">ok( true, "jQuery().html().evalScripts() Evals Scripts Twice in Firefox, see #975" );</script>'));
+ jQuery("#main").html(valueObj('<script type="text/javascript">ok( true, "jQuery().html().evalScripts() Evals Scripts Twice in Firefox, see #975 (1)" );</script>'));
- jQuery("#main").html(valueObj('foo <form><script type="text/javascript">ok( true, "jQuery().html().evalScripts() Evals Scripts Twice in Firefox, see #975" );</script></form>'));
+ jQuery("#main").html(valueObj('foo <form><script type="text/javascript">ok( true, "jQuery().html().evalScripts() Evals Scripts Twice in Firefox, see #975 (2)" );</script></form>'));
// it was decided that waiting to execute ALL scripts makes sense since nested ones have to wait anyway so this test case is changed, see #1959
jQuery("#main").html(valueObj("<script>equals(jQuery.scriptorder++, 0, 'Script is executed in order');equals(jQuery('#scriptorder').length, 1,'Execute after html (even though appears before)')<\/script><span id='scriptorder'><script>equals(jQuery.scriptorder++, 1, 'Script (nested) is executed in order');equals(jQuery('#scriptorder').length, 1,'Execute after html')<\/script></span><script>equals(jQuery.scriptorder++, 2, 'Script (unnested) is executed in order');equals(jQuery('#scriptorder').length, 1,'Execute after html')<\/script>"));
var count = 0;
var first = jQuery("#ap").children(":first");
- first.click(function() { count++ })[method]().appendTo("body").click();
-
+ var cleanUp = first.click(function() { count++ })[method]().appendTo("body").click();
+
equals( method == "remove" ? 0 : 1, count );
+
+ cleanUp.detach();
};
test("remove()", function() {