aboutsummaryrefslogtreecommitdiffstats
path: root/test/unit/css.js
diff options
context:
space:
mode:
Diffstat (limited to 'test/unit/css.js')
-rw-r--r--test/unit/css.js80
1 files changed, 80 insertions, 0 deletions
diff --git a/test/unit/css.js b/test/unit/css.js
index 7e08105d2..a197b6f04 100644
--- a/test/unit/css.js
+++ b/test/unit/css.js
@@ -641,6 +641,63 @@ QUnit.test( "show/hide detached nodes", function( assert ) {
span.remove();
} );
+QUnit[ document.body.attachShadow ? "test" : "skip" ]( "show/hide shadow child nodes", function( assert ) {
+ assert.expect( 28 );
+ jQuery( "<div id='shadowHost'></div>" ).appendTo( "#qunit-fixture" );
+ var shadowHost = document.querySelector( "#shadowHost" );
+ var shadowRoot = shadowHost.attachShadow( { mode: "open" } );
+ shadowRoot.innerHTML = "" +
+ "<style>.hidden{display: none;}</style>" +
+ "<div class='hidden' id='shadowdiv'>" +
+ " <p class='hidden' id='shadowp'>" +
+ " <a href='#' class='hidden' id='shadowa'></a>" +
+ " </p>" +
+ " <code class='hidden' id='shadowcode'></code>" +
+ " <pre class='hidden' id='shadowpre'></pre>" +
+ " <span class='hidden' id='shadowspan'></span>" +
+ "</div>" +
+ "<table class='hidden' id='shadowtable'>" +
+ " <thead class='hidden' id='shadowthead'>" +
+ " <tr class='hidden' id='shadowtr'>" +
+ " <th class='hidden' id='shadowth'></th>" +
+ " </tr>" +
+ " </thead>" +
+ " <tbody class='hidden' id='shadowtbody'>" +
+ " <tr class='hidden'>" +
+ " <td class='hidden' id='shadowtd'></td>" +
+ " </tr>" +
+ " </tbody>" +
+ "</table>" +
+ "<ul class='hidden' id='shadowul'>" +
+ " <li class='hidden' id='shadowli'></li>" +
+ "</ul>";
+
+ var test = {
+ "div": "block",
+ "p": "block",
+ "a": "inline",
+ "code": "inline",
+ "pre": "block",
+ "span": "inline",
+ "table": "table",
+ "thead": "table-header-group",
+ "tbody": "table-row-group",
+ "tr": "table-row",
+ "th": "table-cell",
+ "td": "table-cell",
+ "ul": "block",
+ "li": "list-item"
+ };
+
+ jQuery.each( test, function( selector, expected ) {
+ var shadowChild = shadowRoot.querySelector( "#shadow" + selector );
+ var $shadowChild = jQuery( shadowChild );
+ assert.strictEqual( $shadowChild.css( "display" ), "none", "is hidden" );
+ $shadowChild.show();
+ assert.strictEqual( $shadowChild.css( "display" ), expected, "Show using correct display type for " + selector );
+ } );
+} );
+
QUnit.test( "hide hidden elements (bug #7141)", function( assert ) {
assert.expect( 3 );
@@ -966,6 +1023,29 @@ QUnit[ jQuery.find.compile && jQuery.fn.toggle ? "test" : "skip" ]( "detached to
"cascade-hidden element in detached tree" );
} );
+QUnit[ jQuery.find.compile && jQuery.fn.toggle && document.body.attachShadow ? "test" : "skip" ]( "shadow toggle()", function( assert ) {
+ assert.expect( 4 );
+ jQuery( "<div id='shadowHost'></div>" ).appendTo( "#qunit-fixture" );
+ var shadowHost = document.querySelector( "#shadowHost" );
+ var shadowRoot = shadowHost.attachShadow( { mode: "open" } );
+ shadowRoot.innerHTML = "" +
+ "<style>.hidden{display: none;}</style>" +
+ "<div id='shadowHiddenChild' class='hidden'></div>" +
+ "<div id='shadowChild'></div>";
+ var shadowChild = shadowRoot.querySelector( "#shadowChild" );
+ var shadowHiddenChild = shadowRoot.querySelector( "#shadowHiddenChild" );
+
+ var $shadowChild = jQuery( shadowChild );
+ assert.strictEqual( $shadowChild.css( "display" ), "block", "is visible" );
+ $shadowChild.toggle();
+ assert.strictEqual( $shadowChild.css( "display" ), "none", "is hidden" );
+
+ $shadowChild = jQuery( shadowHiddenChild );
+ assert.strictEqual( $shadowChild.css( "display" ), "none", "is hidden" );
+ $shadowChild.toggle();
+ assert.strictEqual( $shadowChild.css( "display" ), "block", "is visible" );
+} );
+
QUnit.test( "jQuery.css(elem, 'height') doesn't clear radio buttons (bug #1095)", function( assert ) {
assert.expect( 4 );