QUnit.module( "traversing", { afterEach: moduleTeardown } ); QUnit.test( "find(String)", function( assert ) { assert.expect( 1 ); assert.equal( jQuery( "#foo" ).find( ".blogTest" ).text(), "Yahoo", "Basic selector" ); } ); QUnit.test( "find(String) under non-elements", function( assert ) { assert.expect( 2 ); var j = jQuery( "#nonnodes" ).contents(); assert.equal( j.find( "div" ).length, 0, "Check node,textnode,comment to find zero divs" ); assert.equal( j.find( "div" ).addBack().length, 3, "Check node,textnode,comment to find zero divs, but preserves pushStack" ); } ); QUnit.test( "find(leading combinator)", function( assert ) { assert.expect( 4 ); assert.deepEqual( jQuery( "#qunit-fixture" ).find( "> div" ).get(), q( "foo", "nothiddendiv", "moretests", "tabindex-tests", "liveHandlerOrder", "siblingTest", "fx-test-group" ), "find child elements" ); assert.deepEqual( jQuery( "#qunit-fixture" ).find( "> #foo, > #moretests" ).get(), q( "foo", "moretests" ), "find child elements" ); assert.deepEqual( jQuery( "#qunit-fixture" ).find( "> #foo > p" ).get(), q( "sndp", "en", "sap" ), "find child elements" ); assert.deepEqual( jQuery( "#siblingTest, #siblingfirst" ).find( "+ *" ).get(), q( "siblingnext", "fx-test-group" ), "ensure document order" ); } ); QUnit.test( "find(node|jQuery object)", function( assert ) { assert.expect( 13 ); var $foo = jQuery( "#foo" ), $blog = jQuery( ".blogTest" ), $first = jQuery( "#first" ), $two = $blog.add( $first ), $twoMore = jQuery( "#ap" ).add( $blog ), $fooTwo = $foo.add( $blog ); assert.equal( $foo.find( $blog ).text(), "Yahoo", "Find with blog jQuery object" ); assert.equal( $foo.find( $blog[ 0 ] ).text(), "Yahoo", "Find with blog node" ); assert.equal( $foo.find( $first ).length, 0, "#first is not in #foo" ); assert.equal( $foo.find( $first[ 0 ] ).length, 0, "#first not in #foo (node)" ); assert.deepEqual( $foo.find( $two ).get(), $blog.get(), "Find returns only nodes within #foo" ); assert.deepEqual( $foo.find( $twoMore ).get(), $blog.get(), "...regardless of order" ); assert.ok( $fooTwo.find( $blog ).is( ".blogTest" ), "Blog is part of the collection, but also within foo" ); assert.ok( $fooTwo.find( $blog[ 0 ] ).is( ".blogTest" ), "Blog is part of the collection, but also within foo(node)" ); assert.equal( $two.find( $foo ).length, 0, "Foo is not in two elements" ); assert.equal( $two.find( $foo[ 0 ] ).length, 0, "Foo is not in two elements(node)" ); assert.equal( $two.find( $first ).length, 0, "first is in the collection and not within two" ); assert.equal( $two.find( $first ).length, 0, "first is in the collection and not within two(node)" ); assert.equal( $two.find( $foo[ 0 ] ).addBack().length, 2, "find preserves the pushStack, see trac-12009" ); } ); QUnit.test( "is(falsy|invalid)", function( assert ) { assert.expect( 5 ); assert.ok( !jQuery( "#foo" ).is( 0 ), "Expected false for an invalid expression - 0" ); assert.ok( !jQuery( "#foo" ).is( null ), "Expected false for an invalid expression - null" ); assert.ok( !jQuery( "#foo" ).is( "" ), "Expected false for an invalid expression - \"\"" ); assert.ok( !jQuery( "#foo" ).is( undefined ), "Expected false for an invalid expression - undefined" ); assert.ok( !jQuery( "#foo" ).is( { plain: "object" } ), "Check passing invalid object" ); } ); QUnit.test( "is(String)", function( assert ) { assert.expect( 33 ); var link = document.getElementById( "simon1" ), input = document.getElementById( "text1" ), option = document.getElementById( "option1a" ), disconnected = document.createElement( "div" ); assert.ok( jQuery( "#form" ).is( "form" ), "Check for element: A form must be a form" ); assert.ok( !jQuery( "#form" ).is( "div" ), "Check for element: A form is not a div" ); assert.ok( jQuery( "#mark" ).is( ".blog" ), "Check for class: Expected class 'blog'" ); assert.ok( !jQuery( "#mark" ).is( ".link" ), "Check for class: Did not expect class 'link'" ); assert.ok( jQuery( "#simon" ).is( ".blog.link" ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); assert.ok( !jQuery( "#simon" ).is( ".blogTest" ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); assert.ok( jQuery( "#en" ).is( "[lang=\"en\"]" ), "Check for attribute: Expected attribute lang to be 'en'" ); assert.ok( !jQuery( "#en" ).is( "[lang=\"de\"]" ), "Check for attribute: Expected attribute lang to be 'en', not 'de'" ); assert.ok( jQuery( "#text1" ).is( "[type=\"text\"]" ), "Check for attribute: Expected attribute type to be 'text'" ); assert.ok( !jQuery( "#text1" ).is( "[type=\"radio\"]" ), "Check for attribute: Expected attribute type to be 'text', not 'radio'" ); assert.ok( jQuery( "#text2" ).is( ":disabled" ), "Check for pseudoclass: Expected to be disabled" ); assert.ok( !jQuery( "#text1" ).is( ":disabled" ), "Check for pseudoclass: Expected not disabled" ); assert.ok( jQuery( "#radio2" ).is( ":checked" ), "Check for pseudoclass: Expected to be checked" ); assert.ok( !jQuery( "#radio1" ).is( ":checked" ), "Check for pseudoclass: Expected not checked" ); // test is() with comma-separated expressions assert.ok( jQuery( "#en" ).is( "[lang=\"en\"],[lang=\"de\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); assert.ok( jQuery( "#en" ).is( "[lang=\"de\"],[lang=\"en\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); assert.ok( jQuery( "#en" ).is( "[lang=\"en\"] , [lang=\"de\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); assert.ok( jQuery( "#en" ).is( "[lang=\"de\"] , [lang=\"en\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); link.title = "Don't click me"; assert.ok( jQuery( link ).is( "[rel='bookmark']" ), "attribute-equals string (delimited via apostrophes)" ); assert.ok( jQuery( link ).is( "[rel=bookmark]" ), "attribute-equals identifier" ); assert.ok( jQuery( link ).is( "[\nrel = bookmark\t]" ), "attribute-equals identifier (whitespace ignored)" ); assert.ok( jQuery( link ).is( "a[title=\"Don't click me\"]" ), "attribute-equals string containing single quote" ); // jQuery trac-12303 input.setAttribute( "data-pos", ":first" ); assert.ok( jQuery( input ).is( "input[data-pos=\\:first]" ), "attribute-equals POS in identifier" ); assert.ok( jQuery( input ).is( "input[data-pos=':first']" ), "attribute-equals POS in string" ); if ( QUnit.jQuerySelectors ) { assert.ok( jQuery( input ).is( ":input[data-pos=':first']" ), "attribute-equals POS in string after pseudo" ); } else { assert.ok( "skip", ":input not supported in selector-native" ); } option.setAttribute( "test", "" ); assert.ok( jQuery( option ).is( "[id=option1a]" ), "id attribute-equals identifier" ); if ( QUnit.jQuerySelectors ) { assert.ok( jQuery( option ).is( "[id*=option1][type!=checkbox]" ), "attribute-not-equals identifier" ); } else { assert.ok( "skip", "attribute-not-equals not supported in selector-native" ); } assert.ok( jQuery( option ).is( "[id*=option1]" ), "attribute-contains identifier" ); assert.ok( !jQuery( option ).is( "[test^='']" ), "attribute-starts-with empty string (negative)" ); option.className = "=]"; assert.ok( jQuery( option ).is( ".\\=\\]" ), "class selector with attribute-equals confusable" ); assert.ok( jQuery( disconnected ).is( "div" ), "disconnected element" ); assert.ok( jQuery( link ).is( "* > *" ), "child combinator matches in document" ); assert.ok( !jQuery( disconnected ).is( "* > *" ), "child combinator fails in fragment" ); } ); QUnit.test( "is() against non-elements (trac-10178)", function( assert ) { assert.expect( 14 ); var label, i, test, collection = jQuery( document ), tests = [ "a", "*" ], nonelements = { text: document.createTextNode( "" ), comment: document.createComment( "" ), document: document, window: window, array: [], "plain object": {}, "function": function() {} }; for ( label in nonelements ) { collection[ 0 ] = nonelements[ label ]; for ( i = 0; i < tests.length; i++ ) { test = tests[ i ]; assert.ok( !collection.is( test ), label + " does not match \"" + test + "\"" ); } } } ); QUnit.test( "is(jQuery)", function( assert ) { assert.expect( 19 ); assert.ok( jQuery( "#form" ).is( jQuery( "form" ) ), "Check for element: A form is a form" ); assert.ok( !jQuery( "#form" ).is( jQuery( "div" ) ), "Check for element: A form is not a div" ); assert.ok( jQuery( "#mark" ).is( jQuery( ".blog" ) ), "Check for class: Expected class 'blog'" ); assert.ok( !jQuery( "#mark" ).is( jQuery( ".link" ) ), "Check for class: Did not expect class 'link'" ); assert.ok( jQuery( "#simon" ).is( jQuery( ".blog.link" ) ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); assert.ok( !jQuery( "#simon" ).is( jQuery( ".blogTest" ) ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); assert.ok( jQuery( "#en" ).is( jQuery( "[lang=\"en\"]" ) ), "Check for attribute: Expected attribute lang to be 'en'" ); assert.ok( !jQuery( "#en" ).is( jQuery( "[lang=\"de\"]" ) ), "Check for attribute: Expected attribute lang to be 'en', not 'de'" ); assert.ok( jQuery( "#text1" ).is( jQuery( "[type=\"text\"]" ) ), "Check for attribute: Expected attribute type to be 'text'" ); assert.ok( !jQuery( "#text1" ).is( jQuery( "[type=\"radio\"]" ) ), "Check for attribute: Expected attribute type to be 'text', not 'radio'" ); assert.ok( !jQuery( "#text1" ).is( jQuery( "input:disabled" ) ), "Check for pseudoclass: Expected not disabled" ); assert.ok( jQuery( "#radio2" ).is( jQuery( "input:checked" ) ), "Check for pseudoclass: Expected to be checked" ); assert.ok( !jQuery( "#radio1" ).is( jQuery( "input:checked" ) ), "Check for pseudoclass: Expected not checked" ); // Some raw elements assert.ok( jQuery( "#form" ).is( jQuery( "#qunit-fixture form" )[ 0 ] ), "Check for element: A form is a form" ); assert.ok( !jQuery( "#form" ).is( jQuery( "div" )[ 0 ] ), "Check for element: A form is not a div" ); assert.ok( jQuery( "#mark" ).is( jQuery( ".blog" )[ 0 ] ), "Check for class: Expected class 'blog'" ); assert.ok( !jQuery( "#mark" ).is( jQuery( ".link" )[ 0 ] ), "Check for class: Did not expect class 'link'" ); assert.ok( jQuery( "#simon" ).is( jQuery( ".blog.link" )[ 0 ] ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); assert.ok( !jQuery( "#simon" ).is( jQuery( ".blogTest" )[ 0 ] ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); } ); QUnit[ QUnit.jQuerySelectors ? "test" : "skip" ]( "is() with :has() selectors", function( assert ) { assert.expect( 6 ); assert.ok( jQuery( "#foo" ).is( ":has(p)" ), "Check for child: Expected a child 'p' element" ); assert.ok( !jQuery( "#foo" ).is( ":has(ul)" ), "Check for child: Did not expect 'ul' element" ); assert.ok( jQuery( "#foo" ).is( ":has(p):has(a):has(code)" ), "Check for children: Expected 'p', 'a' and 'code' child elements" ); assert.ok( !jQuery( "#foo" ).is( ":has(p):has(a):has(code):has(ol)" ), "Check for children: Expected 'p', 'a' and 'code' child elements, but no 'ol'" ); assert.ok( jQuery( "#foo" ).is( jQuery( "div:has(p)" ) ), "Check for child: Expected a child 'p' element" ); assert.ok( !jQuery( "#foo" ).is( jQuery( "div:has(ul)" ) ), "Check for child: Did not expect 'ul' element" ); } ); QUnit[ QUnit.jQuerySelectorsPos ? "test" : "skip" ]( "is() with positional selectors", function( assert ) { assert.expect( 27 ); var posp = jQuery( "
" ).appendTo( "#qunit-fixture" ), isit = function( sel, match, expect ) { assert.equal( jQuery( sel ).is( match ), expect, "jQuery('" + sel + "').is('" + match + "')" ); }; isit( "#posp", "p:last", true ); isit( "#posp", "#posp:first", true ); isit( "#posp", "#posp:eq(2)", false ); isit( "#posp", "#posp a:first", false ); isit( "#posp .firsta", "#posp a:first", true ); isit( "#posp .firsta", "#posp a:last", false ); isit( "#posp .firsta", "#posp a:even", true ); isit( "#posp .firsta", "#posp a:odd", false ); isit( "#posp .firsta", "#posp a:eq(0)", true ); isit( "#posp .firsta", "#posp a:eq(9)", false ); isit( "#posp .firsta", "#posp em:eq(0)", false ); isit( "#posp .firsta", "#posp em:first", false ); isit( "#posp .firsta", "#posp:first", false ); isit( "#posp .seconda", "#posp a:first", false ); isit( "#posp .seconda", "#posp a:last", true ); isit( "#posp .seconda", "#posp a:gt(0)", true ); isit( "#posp .seconda", "#posp a:lt(5)", true ); isit( "#posp .seconda", "#posp a:lt(1)", false ); isit( "#posp em", "#posp a:eq(0) em", true ); isit( "#posp em", "#posp a:lt(1) em", true ); isit( "#posp em", "#posp a:gt(1) em", false ); isit( "#posp em", "#posp a:first em", true ); isit( "#posp em", "#posp a em:last", true ); isit( "#posp em", "#posp a em:eq(2)", false ); assert.ok( jQuery( "#option1b" ).is( "#select1 option:not(:first)" ), "POS inside of :not() (trac-10970)" ); assert.ok( jQuery( posp[ 0 ] ).is( "p:last" ), "context constructed from a single node (trac-13797)" ); assert.ok( !jQuery( posp[ 0 ] ).find( "#firsta" ).is( "a:first" ), "context derived from a single node (trac-13797)" ); } ); QUnit.test( "index()", function( assert ) { assert.expect( 2 ); assert.equal( jQuery( "#text2" ).index(), 2, "Returns the index of a child amongst its siblings" ); assert.equal( jQuery( "" ).index(), -1, "Node without parent returns -1" ); } ); QUnit.test( "index(Object|String|undefined)", function( assert ) { assert.expect( 16 ); var elements = jQuery( [ window, document ] ), inputElements = jQuery( "#radio1,#radio2,#check1,#check2" ); // Passing a node assert.equal( elements.index( window ), 0, "Check for index of elements" ); assert.equal( elements.index( document ), 1, "Check for index of elements" ); assert.equal( inputElements.index( document.getElementById( "radio1" ) ), 0, "Check for index of elements" ); assert.equal( inputElements.index( document.getElementById( "radio2" ) ), 1, "Check for index of elements" ); assert.equal( inputElements.index( document.getElementById( "check1" ) ), 2, "Check for index of elements" ); assert.equal( inputElements.index( document.getElementById( "check2" ) ), 3, "Check for index of elements" ); assert.equal( inputElements.index( window ), -1, "Check for not found index" ); assert.equal( inputElements.index( document ), -1, "Check for not found index" ); // Passing a jQuery object // enabled since [5500] assert.equal( elements.index( elements ), 0, "Pass in a jQuery object" ); assert.equal( elements.index( elements.eq( 1 ) ), 1, "Pass in a jQuery object" ); assert.equal( jQuery( "#form input[type='radio']" ).index( jQuery( "#radio2" ) ), 1, "Pass in a jQuery object" ); // Passing a selector or nothing // enabled since [6330] assert.equal( jQuery( "#text2" ).index(), 2, "Check for index amongst siblings" ); assert.equal( jQuery( "#form" ).children().eq( 4 ).index(), 4, "Check for index amongst siblings" ); assert.equal( jQuery( "#radio2" ).index( "#form input[type='radio']" ), 1, "Check for index within a selector" ); assert.equal( jQuery( "#form input[type='radio']" ).index( jQuery( "#radio2" ) ), 1, "Check for index within a selector" ); assert.equal( jQuery( "#radio2" ).index( "#form input[type='text']" ), -1, "Check for index not found within a selector" ); } ); QUnit.test( "filter(Selector|undefined)", function( assert ) { assert.expect( 9 ); assert.deepEqual( jQuery( "#form input" ).filter( ":checked" ).get(), q( "radio2", "check1" ), "filter(String)" ); assert.deepEqual( jQuery( "p" ).filter( "#ap, #sndp" ).get(), q( "ap", "sndp" ), "filter('String, String')" ); assert.deepEqual( jQuery( "p" ).filter( "#ap,#sndp" ).get(), q( "ap", "sndp" ), "filter('String,String')" ); assert.deepEqual( jQuery( "p" ).filter( null ).get(), [], "filter(null) should return an empty jQuery object" ); assert.deepEqual( jQuery( "p" ).filter( undefined ).get(), [], "filter(undefined) should return an empty jQuery object" ); assert.deepEqual( jQuery( "p" ).filter( 0 ).get(), [], "filter(0) should return an empty jQuery object" ); assert.deepEqual( jQuery( "p" ).filter( "" ).get(), [], "filter('') should return an empty jQuery object" ); // using contents will get comments regular, text, and comment nodes var j = jQuery( "#nonnodes" ).contents(); assert.equal( j.filter( "span" ).length, 1, "Check node,textnode,comment to filter the one span" ); assert.equal( j.filter( "[name]" ).length, 0, "Check node,textnode,comment to filter the one span" ); } ); QUnit.test( "filter(Function)", function( assert ) { assert.expect( 2 ); assert.deepEqual( jQuery( "#qunit-fixture p" ).filter( function() { return !jQuery( "a", this ).length; } ).get(), q( "sndp", "first" ), "filter(Function)" ); assert.deepEqual( jQuery( "#qunit-fixture p" ).filter( function( i, elem ) { return !jQuery( "a", elem ).length; } ).get(), q( "sndp", "first" ), "filter(Function) using arg" ); } ); QUnit.test( "filter(Element)", function( assert ) { assert.expect( 1 ); var element = document.getElementById( "text1" ); assert.deepEqual( jQuery( "#form input" ).filter( element ).get(), q( "text1" ), "filter(Element)" ); } ); QUnit.test( "filter(Array)", function( assert ) { assert.expect( 1 ); var elements = [ document.getElementById( "text1" ) ]; assert.deepEqual( jQuery( "#form input" ).filter( elements ).get(), q( "text1" ), "filter(Element)" ); } ); QUnit.test( "filter(jQuery)", function( assert ) { assert.expect( 1 ); var elements = jQuery( "#text1" ); assert.deepEqual( jQuery( "#form input" ).filter( elements ).get(), q( "text1" ), "filter(Element)" ); } ); QUnit[ QUnit.jQuerySelectorsPos ? "test" : "skip" ]( "filter() with positional selectors", function( assert ) { assert.expect( 19 ); var filterit = function( sel, filter, length ) { assert.equal( jQuery( sel ).filter( filter ).length, length, "jQuery( " + sel + " ).filter( " + filter + " )" ); }; jQuery( "" + "" + "" + "first" + "" + "" + "test" + "" + "" + "
" ).appendTo( "#qunit-fixture" ); filterit( "#posp", "#posp:first", 1 ); filterit( "#posp", "#posp:eq(2)", 0 ); filterit( "#posp", "#posp a:first", 0 ); // Keep in mind this is within the selection and // not in relation to other elements (.is() is a different story) filterit( "#posp .firsta", "#posp a:first", 1 ); filterit( "#posp .firsta", "#posp a:last", 1 ); filterit( "#posp .firsta", "#posp a:last-child", 0 ); filterit( "#posp .firsta", "#posp a:even", 1 ); filterit( "#posp .firsta", "#posp a:odd", 0 ); filterit( "#posp .firsta", "#posp a:eq(0)", 1 ); filterit( "#posp .firsta", "#posp a:eq(9)", 0 ); filterit( "#posp .firsta", "#posp em:eq(0)", 0 ); filterit( "#posp .firsta", "#posp em:first", 0 ); filterit( "#posp .firsta", "#posp:first", 0 ); filterit( "#posp .seconda", "#posp a:first", 1 ); filterit( "#posp .seconda", "#posp em:first", 0 ); filterit( "#posp .seconda", "#posp a:last", 1 ); filterit( "#posp .seconda", "#posp a:gt(0)", 0 ); filterit( "#posp .seconda", "#posp a:lt(5)", 1 ); filterit( "#posp .seconda", "#posp a:lt(1)", 1 ); } ); QUnit.test( "closest()", function( assert ) { assert.expect( 14 ); var jq; assert.deepEqual( jQuery( "body" ).closest( "body" ).get(), q( "body" ), "closest(body)" ); assert.deepEqual( jQuery( "body" ).closest( "html" ).get(), q( "html" ), "closest(html)" ); assert.deepEqual( jQuery( "body" ).closest( "div" ).get(), [], "closest(div)" ); assert.deepEqual( jQuery( "#qunit-fixture" ).closest( "span,#html" ).get(), q( "html" ), "closest(span,#html)" ); // Test .closest() limited by the context jq = jQuery( "#nothiddendivchild" ); assert.deepEqual( jq.closest( "html", document.body ).get(), [], "Context limited." ); assert.deepEqual( jq.closest( "body", document.body ).get(), [], "Context limited." ); assert.deepEqual( jq.closest( "#nothiddendiv", document.body ).get(), q( "nothiddendiv" ), "Context not reached." ); //Test that .closest() returns unique'd set assert.equal( jQuery( "#qunit-fixture p" ).closest( "#qunit-fixture" ).length, 1, "Closest should return a unique set" ); // Test on disconnected node assert.equal( jQuery( "
" +
""
);
var content = jQuery( "#template" ).contents();
assert.strictEqual( window.testScript, true, "script in template isn't executed" );
assert.strictEqual( window.testImgOnload, true, "onload of image in template isn't executed" );
} );
QUnit.test( "contents() for ", function( assert ) {
assert.expect( 2 );
var svgObject = jQuery( "" );
var done = assert.async();
svgObject.on( "load", function() {
var contents = jQuery( "#svg-object" ).contents();
assert.equal( contents.length, 1, "Check object contents" );
assert.equal( contents.find( "svg" ).length, 1, "Find svg within object" );
done();
} );
jQuery( "#qunit-fixture" ).append( svgObject );
} );
QUnit.test( "contents() for with children", function( assert ) {
assert.expect( 1 );
var object = "";
var contents = jQuery( object ).contents();
assert.equal( contents.length, 3, "Check object contents children are correct" );
} );
QUnit.test( "contents() for ", function( assert ) {
assert.expect( 2 );
var iframe = jQuery( "" );
var done = assert.async();
iframe.on( "load", function() {
var container = jQuery( "#frame-contents" ).contents();
var contents = container.find( "#test-frame" ).contents();
assert.equal( contents.length, 1, "Check frame contents" );
assert.equal( contents.find( "body" ).length, 1, "Find body within frame" );
done();
} );
jQuery( "#qunit-fixture" ).append( iframe );
} );
QUnit.test( "sort direction", function( assert ) {
assert.expect( 12 );
var elems = jQuery( "#ap, #select1 > *, #moretests > form" ),
methodDirections = {
parent: false,
parents: true,
parentsUntil: true,
next: false,
prev: false,
nextAll: false,
prevAll: true,
nextUntil: false,
prevUntil: true,
siblings: false,
children: false,
contents: false
};
jQuery.each( methodDirections, function( method, reversed ) {
var actual = elems[ method ]().get(),
forward = jQuery.uniqueSort( [].concat( actual ) );
assert.deepEqual( actual, reversed ? forward.reverse() : forward, "Correct sort direction for " + method );
} );
} );
QUnit.test( "add(String selector)", function( assert ) {
assert.expect( 2 );
var divs;
assert.deepEqual(
jQuery( "#sndp" ).add( "#en" ).add( "#sap" ).toArray(),
q( "sndp", "en", "sap" ),
"Check elements from document"
);
divs = jQuery( "" ).add( "#sndp" );
assert.ok( divs[ 0 ].parentNode, "Sort with the disconnected node last (started with disconnected first)." );
} );
QUnit.test( "add(String selector, String context)", function( assert ) {
assert.expect( 1 );
assert.deepEqual(
jQuery( [] ).add( "div", "#nothiddendiv" ).toArray(),
q( "nothiddendivchild" ),
"Check elements from document"
);
} );
QUnit.test( "add(String html)", function( assert ) {
assert.expect( 3 );
var x,
divs = jQuery( "#sndp" ).add( "" );
assert.ok( !divs[ 1 ].parentNode, "Sort with the disconnected node last." );
x = jQuery( [] ).add( "xxx
" ).add( "xxx
" ); assert.equal( x[ 0 ].id, "x1", "Check detached element1" ); assert.equal( x[ 1 ].id, "x2", "Check detached element2" ); } ); QUnit.test( "add(jQuery)", function( assert ) { assert.expect( 4 ); var x, tmp = jQuery( "" ); x = jQuery( [] ) .add( jQuery( "xxx
" ).appendTo( tmp ) ) .add( jQuery( "xxx
" ).appendTo( tmp ) ); assert.equal( x[ 0 ].id, "x1", "Check element1 in detached parent" ); assert.equal( x[ 1 ].id, "x2", "Check element2 in detached parent" ); x = jQuery( [] ) .add( jQuery( "xxx
" ) ) .add( jQuery( "xxx
" ) ); assert.equal( x[ 0 ].id, "x1", "Check detached element1" ); assert.equal( x[ 1 ].id, "x2", "Check detached element2" ); } ); QUnit.test( "add(Element)", function( assert ) { assert.expect( 2 ); var x, tmp = jQuery( "" ); x = jQuery( [] ).add( jQuery( "xxx
" ).appendTo( tmp )[ 0 ] ).add( jQuery( "xxx
" ).appendTo( tmp )[ 0 ] ); assert.equal( x[ 0 ].id, "x1", "Check on-the-fly element1" ); assert.equal( x[ 1 ].id, "x2", "Check on-the-fly element2" ); } ); QUnit.test( "add(Array elements)", function( assert ) { assert.expect( 1 ); assert.deepEqual( jQuery( "#sndp" ).add( jQuery( "#en" )[ 0 ] ).add( jQuery( "#sap" ) ).toArray(), q( "sndp", "en", "sap" ), "Check elements from document" ); } ); QUnit.test( "add(Window)", function( assert ) { assert.expect( 1 ); var frame1 = document.createElement( "iframe" ), frame2 = document.createElement( "iframe" ); // This increases window.length and sets window[i] available document.body.appendChild( frame1 ); document.body.appendChild( frame2 ); // Window is tricky because it is a lot like an array, even Array#slice will // turn it into a multi-item array. assert.equal( jQuery( [] ).add( window ).length, 1, "Add a window" ); document.body.removeChild( frame1 ); document.body.removeChild( frame2 ); } ); QUnit.test( "add(NodeList|undefined|HTMLFormElement|HTMLSelectElement)", function( assert ) { assert.expect( 4 ); var ps, notDefined; ps = document.getElementsByTagName( "p" ); assert.equal( jQuery( [] ).add( ps ).length, ps.length, "Add a NodeList" ); assert.equal( jQuery( [] ).add( notDefined ).length, 0, "Adding undefined adds nothing" ); assert.equal( jQuery( [] ).add( document.getElementById( "form" ) ).length, 1, "Add a form" ); assert.equal( jQuery( [] ).add( document.getElementById( "select1" ) ).length, 1, "Add a select" ); // We no longer support .add(form.elements), unfortunately. // There is no way, in browsers, to reliably determine the difference // between form.elements and form - and doing .add(form) and having it // add the form elements is way to unexpected, so this gets the boot. //ok( jQuery([]).add(jQuery("#form")[0].elements).length >= 13, "Check elements from array" ); // For the time being, we're discontinuing support for jQuery(form.elements) since it's ambiguous in IE // use jQuery([]).add(form.elements) instead. //equal( jQuery([]).add(jQuery("#form")[0].elements).length, jQuery(jQuery("#form")[0].elements).length, "Array in constructor must equals array in add()" ); } ); QUnit.test( "add(String, Context)", function( assert ) { assert.expect( 6 ); assert.deepEqual( jQuery( "#firstp" ).add( "#ap" ).get(), q( "firstp", "ap" ), "Add selector to selector " ); assert.deepEqual( jQuery( document.getElementById( "firstp" ) ).add( "#ap" ).get(), q( "firstp", "ap" ), "Add gEBId to selector" ); assert.deepEqual( jQuery( document.getElementById( "firstp" ) ).add( document.getElementById( "ap" ) ).get(), q( "firstp", "ap" ), "Add gEBId to gEBId" ); var ctx = document.getElementById( "firstp" ); assert.deepEqual( jQuery( "#firstp" ).add( "#ap", ctx ).get(), q( "firstp" ), "Add selector to selector " ); assert.deepEqual( jQuery( document.getElementById( "firstp" ) ).add( "#ap", ctx ).get(), q( "firstp" ), "Add gEBId to selector, not in context" ); assert.deepEqual( jQuery( document.getElementById( "firstp" ) ).add( "#ap", document.getElementsByTagName( "body" )[ 0 ] ).get(), q( "firstp", "ap" ), "Add gEBId to selector, in context" ); } ); QUnit.test( "eq('-1') trac-10616", function( assert ) { assert.expect( 3 ); var $divs = jQuery( "div" ); assert.equal( $divs.eq( -1 ).length, 1, "The number -1 returns a selection that has length 1" ); assert.equal( $divs.eq( "-1" ).length, 1, "The string '-1' returns a selection that has length 1" ); assert.deepEqual( $divs.eq( "-1" ), $divs.eq( -1 ), "String and number -1 match" ); } ); QUnit.test( "index(no arg) trac-10977", function( assert ) { assert.expect( 2 ); var $list, fragment, div; $list = jQuery( "
" +
""
);
var content = jQuery( "#template" ).contents();
assert.strictEqual( window.testScript, true, "script in template isn't executed" );
assert.strictEqual( window.testImgOnload, true, "onload of image in template isn't executed" );
} );
QUnit.test( "contents() for ", function( assert ) {
assert.expect( 2 );
var svgObject = jQuery( "" );
var done = assert.async();
svgObject.on( "load", function() {
var contents = jQuery( "#svg-object" ).contents();
assert.equal( contents.length, 1, "Check object contents" );
assert.equal( contents.find( "svg" ).length, 1, "Find svg within object" );
done();
} );
jQuery( "#qunit-fixture" ).append( svgObject );
} );
QUnit.test( "contents() for with children", function( assert ) {
assert.expect( 1 );
var object = "";
var contents = jQuery( object ).contents();
assert.equal( contents.length, 3, "Check object contents children are correct" );
} );
QUnit.test( "contents() for ", function( assert ) {
assert.expect( 2 );
var iframe = jQuery( "" );
var done = assert.async();
iframe.on( "load", function() {
var container = jQuery( "#frame-contents" ).contents();
var contents = container.find( "#test-frame" ).contents();
assert.equal( contents.length, 1, "Check frame contents" );
assert.equal( contents.find( "body" ).length, 1, "Find body within frame" );
done();
} );
jQuery( "#qunit-fixture" ).append( iframe );
} );
QUnit.test( "sort direction", function( assert ) {
assert.expect( 12 );
var elems = jQuery( "#ap, #select1 > *, #moretests > form" ),
methodDirections = {
parent: false,
parents: true,
parentsUntil: true,
next: false,
prev: false,
nextAll: false,
prevAll: true,
nextUntil: false,
prevUntil: true,
siblings: false,
children: false,
contents: false
};
jQuery.each( methodDirections, function( method, reversed ) {
var actual = elems[ method ]().get(),
forward = jQuery.uniqueSort( [].concat( actual ) );
assert.deepEqual( actual, reversed ? forward.reverse() : forward, "Correct sort direction for " + method );
} );
} );
QUnit.test( "add(String selector)", function( assert ) {
assert.expect( 2 );
var divs;
assert.deepEqual(
jQuery( "#sndp" ).add( "#en" ).add( "#sap" ).toArray(),
q( "sndp", "en", "sap" ),
"Check elements from document"
);
divs = jQuery( "" ).add( "#sndp" );
assert.ok( divs[ 0 ].parentNode, "Sort with the disconnected node last (started with disconnected first)." );
} );
QUnit.test( "add(String selector, String context)", function( assert ) {
assert.expect( 1 );
assert.deepEqual(
jQuery( [] ).add( "div", "#nothiddendiv" ).toArray(),
q( "nothiddendivchild" ),
"Check elements from document"
);
} );
QUnit.test( "add(String html)", function( assert ) {
assert.expect( 3 );
var x,
divs = jQuery( "#sndp" ).add( "" );
assert.ok( !divs[ 1 ].parentNode, "Sort with the disconnected node last." );
x = jQuery( [] ).add( "