File: table-ua-stylesheet.html

package info (click to toggle)
firefox 143.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,617,328 kB
  • sloc: cpp: 7,478,492; javascript: 6,417,157; ansic: 3,720,058; python: 1,396,372; xml: 627,523; asm: 438,677; java: 186,156; sh: 63,477; makefile: 19,171; objc: 13,059; perl: 12,983; yacc: 4,583; cs: 3,846; pascal: 3,405; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 53; csh: 10
file content (44 lines) | stat: -rw-r--r-- 1,965 bytes parent folder | download | duplicates (25)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<!DOCTYPE html>
<meta charset="utf-8">
<title>Test for table element's UA-stylesheet-provided styles</title>
<link rel="help" href="https://html.spec.whatwg.org/multipage/rendering.html#the-css-user-agent-style-sheet-and-presentational-hints">
<link rel="help" href="https://html.spec.whatwg.org/multipage/rendering.html#tables-2">
<link rel="author" title="Daniel Holbert" href="mailto:dholbert@mozilla.com">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>

<div id="refElem"></div>
<!-- Note: this test puts the table inside of an element with a non-default
     'text-indent' and 'border-collapse' values, so that we can verify that
     the table does indeed use the initial value for these properties, rather
     than simply inheriting. -->
<div style="text-indent: 100px; border-collapse: collapse">
  <table id="tableElem"></table>
</div>

<script>
/* These styles come from the default `table` styling here:
 *  https://html.spec.whatwg.org/multipage/rendering.html#tables-2
 * We can't check for these values directly, because they may be
 * serialized slightly differently when read from the computed style.
 * So, for each property here, we apply it to a "reference" div and then
 * read back the computed value, and we validate that a table element
 * has that same computed value by default. */
const defaultTablePropVals = {
  'display':         'table',
  'box-sizing':      'border-box',
  'border-spacing':  '2px',
  'border-collapse': 'separate',
  'text-indent':     'initial',
};

for (var propName in defaultTablePropVals) {
  test(function() {
    refElem.style[propName] = defaultTablePropVals[propName];
    let expectedComputedVal = getComputedStyle(refElem, "")[propName];

    let actualComputedVal = getComputedStyle(tableElem, "")[propName];
    assert_equals(actualComputedVal, expectedComputedVal);
  }, `Computed '${propName}' on table should match html spec`);
}
</script>