File: test-ua-stylesheet.js

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 (74 lines) | stat: -rw-r--r-- 2,400 bytes parent folder | download | duplicates (11)
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
function runUAStyleTests(props) {
  const refs = document.getElementById('refs');
  for (const el of document.querySelectorAll('#tests > *')) {
   const clone = fakeClone(el);
   refs.append(clone);
  }
  const testsContainer = document.getElementById('tests');
  const testEls = document.querySelectorAll('#tests *');
  const refEls = document.querySelectorAll('#refs *');
  for (let i = 0; i < testEls.length; ++i) {
   const testEl = testEls[i];
   if (testEl.hasAttribute('data-skip')) {
     continue;
   }
   const refEl = refEls[i];
   const testStyle = getComputedStyle(testEl);
   const refStyle = getComputedStyle(refEl);
   for (const prop of props) {
     // Don't test display for some elements.
     // TODO(zcorpan): https://github.com/whatwg/html/issues/4093
     // TODO(zcorpan): https://github.com/whatwg/html/issues/5063
     if (prop === 'display' &&
         (testEl.localName === 'optgroup' ||
          testEl.localName === 'option' ||
          testEl.localName === 'marquee')
      ) {
      continue;
     }
     if (prop === 'overflow' && testEl.localName === 'select') {
      // TODO: https://github.com/whatwg/html/issues/10031
      continue;
     }
     test(() => {
       assert_equals(testStyle.getPropertyValue(prop), refStyle.getPropertyValue(prop));
     }, `${testNameContext(testEl)} - ${prop}`);
   }
  }

  function fakeClone(el) {
   const clone = document.createElementNS('urn:not-html', el.localName);
   for (const att of el.attributes) {
     clone.setAttributeNS(att.namespaceURI, att.name, att.value);
   }
   // deep clone
   for (const child of el.children) {
     clone.append(fakeClone(child));
   }
   return clone;
  }

  function testNameContext(el) {
   const outerHTML = el.outerHTML;
   const startTags = outerHTML.substring(0, outerHTML.indexOf('</')) || outerHTML;

   let ancestors = [];
   let current = el.parentNode;
   while (current != testsContainer) {
     ancestors.unshift(`<${current.localName}${contextAttrs(current.attributes)}>`);
     current = current.parentNode;
   }
   return startTags + (ancestors.length ? ` (in ${ancestors.join('')})` : '');
  }

  function contextAttrs(attributes) {
    let rv = "";
    for (let i = 0; i < attributes.length; ++i) {
      if (attributes[i].name === 'data-skip') {
        continue;
      }
      rv += ` ${attributes[i].name}="${attributes[i].value}"`;
    }
    return rv;
  }
}