<!doctype html>
<script src='/resources/testharness.js'></script>
<script src='/resources/testharnessreport.js'></script>
<link rel='stylesheet' href='./support/base.css' />
<link rel="help" href="https://drafts.csswg.org/css-tables-3/#mapping">
<main>
<h1>HTML-2-CSS Mapping</h1>
<p>Checks that browsers implement properly the html2css stylesheet (rules about borders, disabling border-collapse for clarity)</p>
<style>table { border-collapse: separate !important; }</style>
<hr/>
<p>1: The border of the table element should be 0px hidden gray:</p>
<p>
<code>border-width:0px</code> is the <code>initial</code> value;<br/>
<code>border-style:hidden</code> comes from <code>table:matches(..., [rules=groups], ...)</code>;<br/>
<code>border-color:gray</code> comes from <code>table</code>
</p>
<div><table border="0" rules="groups"><tbody><tr><td></td></tr></tbody></table></div>
<hr/>
<p>2: The border of the table element should be 1px outset black:</p>
<p>
<code>border-width:1px</code> comes from <code>table[frame=box] (1/2)</code>;<br/>
<code>border-style:outset</code> comes from <code>table[frame=box] (2/2)</code>;<br/>
<code>border-color:black</code> comes from <code>table:matches(..., [rules=groups], ...)</code>
</p>
<div><table border="0" rules="groups" frame="box"><tbody><tr><td></td></tr></tbody></table></div>
<hr/>
<p>3a: The border of the table element should be 10px outset gray:</p>
<p>
<code>border-width:10px</code> comes from <code>table[border=$w]</code>;<br/>
<code>border-style:outset</code> comes from <code>table[frame=box] (2/2)</code>;<br/>
<code>border-color:gray</code> comes from <code>table[border=$w]</code>
</p>
<hr style="display:none"/>
<p>3b: The border-top of the td element should be 1px inset gray:</p>
<p>
<code>border-width:1px</code> comes from <code>table[border=$w] > ...td</code>;<br/>
<code>border-style:inset</code> comes from <code>table[border=$w] > ...td</code>;<br/>
<code>border-color:gray</code> comes from <code>table[border=$w] > ...td</code>
</p>
<hr style="display:none"/>
<p>3c: The border-left of the td element should be 1px hidden gray:</p>
<p>
<code>border-width:1px</code> comes from <code>table[border=$w] > ...td</code>;<br/>
<code>border-style:inset</code> comes from <code>table[border=$w] > ...td</code>;<br/>
<code>border-color:gray</code> comes from <code>table[border=$w] > ...td</code>
</p>
<div><table border="10" rules="groups" frame="box"><tbody><tr><td></td></tr></tbody></table></div>
<hr/>
<p>4a: The border of the table element should be 1px outset gray:</p>
<p>
<code>border-width:10px</code> comes from <code>table[border=$w]</code>;<br/>
<code>border-style:outset</code> comes from <code>table[border=$w]</code>;<br/>
<code>border-color:gray</code> comes from <code>table[border=$w]</code>
</p>
<hr style="display:none">
<p>4b: The top border of the td element should be 1px solid gray:</p>
<p>
<code>border-width:1px</code> comes from <code>table[rules=all] > ... td</code>;<br/>
<code>border-style:solid</code> comes from <code>table[rules=all] > ... td</code>;<br/>
<code>border-color:gray</code> comes from <code>table[rules=all] > ... td</code>
</p>
<div><table border="yes" rules="all"><tr><td></td></tr></table></div>
<hr>
<p>5a: The left border of the table element should be ? hidden ?:</p>
<p>
<code>border-style:hidden</code> comes from <code>table[frame=hsides]</code>;<br/>
</p>
<hr style="display:none">
<p>5b: The right border of the table element should be 10px solid gray:</p>
<p>
<code>border-width:10px</code> comes from <code>table[border=$w]</code>;<br/>
<code>border-style:solid</code> comes from <code>[style]</code>;<br/>
<code>border-color:gray</code> comes from <code>table[border=$w]</code>
</p>
<div><table border="10" frame="hsides" style="border-right-style: solid"><tr><td></td></tr></table></div>
<script>void function() { var table; while(table = document.querySelector('.to-remove')) table.parentNode.replaceChild(table.firstChild,table) }();</script>
<script>void function() { var td; while(td = document.querySelector('table.no-td td')) td.parentNode.replaceChild(document.createElement('x-td'),td) }();</script>
<script>void function() { var divs = document.querySelectorAll("main > div"); for(var i = divs.length; i--;) { var div = divs[i]; var pre = document.createElement('pre'); pre.title = pre.textContent = div.innerHTML; div.parentNode.insertBefore(pre, div); }; }();</script>
<hr/>
</main>
<script>
var i = 1;
generate_tests(assert_equals, [
/*========================================*/
[
"1: HTML -> CSS Mapping for borders is applied correctly on table markup (table left width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i++)+") table")).borderLeftWidth,
"0px"
],
[
"1: HTML -> CSS Mapping for borders is applied correctly on table markup (table left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftStyle,
"hidden"
],
[
"1: HTML -> CSS Mapping for borders is applied correctly on table markup (table left color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftColor,
"rgb(128, 128, 128)"
],
/*========================================*/
[
"2: HTML -> CSS Mapping for borders is applied correctly on table markup (table left width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i++)+") table")).borderLeftWidth,
"1px"
],
[
"2: HTML -> CSS Mapping for borders is applied correctly on table markup (table left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftStyle,
"outset"
],
[
"2: HTML -> CSS Mapping for borders is applied correctly on table markup (table left color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftColor,
"rgb(0, 0, 0)"
],
/*========================================*/
[
"3a: HTML -> CSS Mapping for borders is applied correctly on table markup (table left width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i++)+") table")).borderLeftWidth,
"10px"
],
[
"3a: HTML -> CSS Mapping for borders is applied correctly on table markup (table left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftStyle,
"outset"
],
[
"3a: HTML -> CSS Mapping for borders is applied correctly on table markup (table left color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftColor,
"rgb(128, 128, 128)"
],
[
"3b: HTML -> CSS Mapping for borders is applied correctly on table markup (td top width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderTopWidth,
"1px"
],
[
"3b: HTML -> CSS Mapping for borders is applied correctly on table markup (td top style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderTopStyle,
"inset"
],
[
"3b: HTML -> CSS Mapping for borders is applied correctly on table markup (td top color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderTopColor,
"rgb(128, 128, 128)"
],
[
"3c: HTML -> CSS Mapping for borders is applied correctly on table markup (td left width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderLeftWidth,
"1px"
],
[
"3c: HTML -> CSS Mapping for borders is applied correctly on table markup (td left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderLeftStyle,
"inset"
],
[
"3c: HTML -> CSS Mapping for borders is applied correctly on table markup (td left color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderLeftColor,
"rgb(128, 128, 128)"
],
/*========================================*/
[
"4: HTML -> CSS Mapping for borders is applied correctly on table markup (table left width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i++)+") table")).borderLeftWidth,
"1px"
],
[
"4: HTML -> CSS Mapping for borders is applied correctly on table markup (table left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftStyle,
"outset"
],
[
"4: HTML -> CSS Mapping for borders is applied correctly on table markup (table left color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderLeftColor,
"rgb(128, 128, 128)"
],
[
"4: HTML -> CSS Mapping for borders is applied correctly on table markup (td left width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderLeftWidth,
"1px"
],
[
"4: HTML -> CSS Mapping for borders is applied correctly on table markup (td left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderLeftStyle,
"solid"
],
[
"4: HTML -> CSS Mapping for borders is applied correctly on table markup (td left color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table td")).borderLeftColor,
"rgb(128, 128, 128)"
],
/*========================================*/
[
"5a: HTML -> CSS Mapping for borders is applied correctly on table markup (table left style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i++)+") table")).borderLeftStyle,
"hidden"
],
[
"5b: HTML -> CSS Mapping for borders is applied correctly on table markup (table right width)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderRightWidth,
"10px"
],
[
"5b: HTML -> CSS Mapping for borders is applied correctly on table markup (table right style)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderRightStyle,
"solid"
],
[
"5b: HTML -> CSS Mapping for borders is applied correctly on table markup (table right color)",
getComputedStyle(document.querySelector("main > div:nth-of-type("+(i-1)+") table")).borderRightColor,
"rgb(128, 128, 128)"
],
])
</script>