Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 <!DOCTYPE html> | |
| 2 <script src="../../../resources/testharness.js"></script> | |
| 3 <script src="../../../resources/testharnessreport.js"></script> | |
| 4 <div id="log"></div> | |
|
rune
2016/05/25 23:43:07
Is the #log element necessary?
kojii
2016/05/26 01:25:40
Good point. Until recently, our testharnessreport.
| |
| 5 <iframe id="iframe"></iframe> | |
| 6 <script> | |
| 7 const testList = [ | |
| 8 { name: 'div', defined: true }, | |
| 9 { name: 'a-a', defined: false }, | |
| 10 { name: 'font-face', defined: true }, | |
| 11 ]; | |
| 12 | |
| 13 // Setup iframe to test the parser. | |
| 14 const neither = 'rgb(255, 0, 0)'; | |
| 15 const defined = 'rgb(255, 165, 0)'; | |
| 16 const not_defined = 'rgb(0, 0, 255)'; | |
| 17 iframe.srcdoc = '<style>' | |
| 18 + `* { color:${neither}; }` | |
|
rune
2016/05/25 23:43:07
Looks like you're mixing single-quotes and back-ti
kojii
2016/05/26 01:25:40
Only back-ticks does template literals which I rec
kojii
2016/05/26 04:49:43
I happen to find the back-ticks support new-lines
rune
2016/05/26 07:16:27
No looks good now. Excuse my ES6 ignorance. I didn
| |
| 19 + `:defined { color:${defined}; }` | |
| 20 + `:not(:defined) { color:${not_defined}; }` | |
| 21 + '</style>' | |
| 22 + testList.map(d => `<${d.name}></${d.name}>`).join(''); | |
| 23 setup({ explicit_done: true }); | |
| 24 iframe.onload = () => { | |
| 25 const doc = iframe.contentDocument; | |
| 26 | |
| 27 for (const data of testList) { | |
| 28 test_defined(data.defined, doc.getElementsByTagName(data.name)[0], `<${data. name}>`); | |
| 29 | |
| 30 let element = doc.createElement(data.name); | |
| 31 doc.body.appendChild(element); | |
| 32 test_defined(data.defined, element, `createElement("${data.name}")`); | |
| 33 | |
| 34 element = doc.createElementNS('http://www.w3.org/1999/xhtml', data.name); | |
| 35 doc.body.appendChild(element); | |
| 36 test_defined(data.defined, element, `createElementNS("http://www.w3.org/1999 /xhtml", "${data.name}")`); | |
| 37 | |
| 38 element = doc.createElementNS('http://www.w3.org/2000/svg', data.name); | |
| 39 doc.body.appendChild(element); | |
| 40 test_defined(true, element, `createElementNS("http://www.w3.org/2000/svg", " ${data.name}")`); | |
| 41 } | |
| 42 | |
| 43 function test_defined(expected, element, description) { | |
| 44 test(() => { | |
| 45 assert_equals(element.matches(':defined'), expected, 'matches(":defined")' ); | |
| 46 assert_equals(element.matches(':not(:defined)'), !expected, 'matches(":not (:defined")'); | |
| 47 assert_equals(doc.defaultView.getComputedStyle(element).color, expected ? defined : not_defined, 'getComputedStyle'); | |
| 48 }, `${description} should ${expected ? 'be' : 'not be'} :defined`); | |
| 49 } | |
| 50 | |
| 51 done(); | |
| 52 }; | |
| 53 </script> | |
| OLD | NEW |