OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <html> | 2 <html> |
3 <head> | 3 <head> |
4 <script src="resources/shadow-dom.js"></script> | 4 <script src="resources/shadow-dom.js"></script> |
5 <script src="../../../resources/js-test.js"></script> | 5 <script src="../../../resources/js-test.js"></script> |
6 </head> | 6 </head> |
7 <body> | 7 <body> |
8 <div id='sandbox'> | 8 <div id='sandbox'> |
9 </div> | 9 </div> |
10 </body> | 10 </body> |
11 <script> | 11 <script> |
12 var borderColor; | 12 var borderColor; |
13 | 13 |
14 function colorOf(node) | 14 function colorOf(node) |
15 { | 15 { |
16 return document.defaultView.getComputedStyle(node, null).getPropertyValue('c
olor'); | 16 return document.defaultView.getComputedStyle(node, null).getPropertyValue('c
olor'); |
17 } | 17 } |
18 | 18 |
19 function colorShouldBe(selector, color) | 19 function colorShouldBe(selector, color) |
20 { | 20 { |
21 var text = 'colorOf(getNodeInTreeOfTrees("' + selector + '"))'; | 21 var text = 'colorOf(getNodeInComposedTree("' + selector + '"))'; |
22 shouldBeEqualToString(text, color); | 22 shouldBeEqualToString(text, color); |
23 } | 23 } |
24 | 24 |
25 function colorShouldNotBe(selector, color) | 25 function colorShouldNotBe(selector, color) |
26 { | 26 { |
27 var text = 'colorOf(getNodeInTreeOfTrees("' + selector + '"))'; | 27 var text = 'colorOf(getNodeInComposedTree("' + selector + '"))'; |
28 var unevaledString = '"' + color.replace(/\\/g, "\\\\").replace(/"/g, "\"")
+ '"'; | 28 var unevaledString = '"' + color.replace(/\\/g, "\\\\").replace(/"/g, "\"")
+ '"'; |
29 shouldNotBe(text, unevaledString); | 29 shouldNotBe(text, unevaledString); |
30 } | 30 } |
31 | 31 |
32 function cleanUp() | 32 function cleanUp() |
33 { | 33 { |
34 document.getElementById('sandbox').innerHTML = ''; | 34 document.getElementById('sandbox').innerHTML = ''; |
35 } | 35 } |
36 | 36 |
37 description('crbug.com/337573: Test direct/indirect adjucent and positinal rules
under shadow root.'); | 37 description('crbug.com/337573: Test direct/indirect adjucent and positinal rules
under shadow root.'); |
38 | 38 |
39 sandbox.appendChild( | 39 sandbox.appendChild( |
40 createDOM('div', {'id': 'host'}, | 40 createDOM('div', {'id': 'host'}, |
41 createShadowRoot( | 41 createShadowRoot( |
42 createDOM('style', {}, | 42 createDOM('style', {}, |
43 document.createTextNode('#child1.target + #child2 { color: green
}')), | 43 document.createTextNode('#child1.target + #child2 { color: green
}')), |
44 createDOM('div', {'id': 'child1'}, | 44 createDOM('div', {'id': 'child1'}, |
45 document.createTextNode('first div')), | 45 document.createTextNode('first div')), |
46 createDOM('div', {'id': 'child2'}, | 46 createDOM('div', {'id': 'child2'}, |
47 document.createTextNode('second div'))))); | 47 document.createTextNode('second div'))))); |
48 document.body.offsetLeft; | 48 document.body.offsetLeft; |
49 getNodeInTreeOfTrees('host/child1').className = 'target'; | 49 getNodeInComposedTree('host/child1').className = 'target'; |
50 colorShouldBe('host/child2', 'rgb(0, 128, 0)'); | 50 colorShouldBe('host/child2', 'rgb(0, 128, 0)'); |
51 | 51 |
52 cleanUp(); | 52 cleanUp(); |
53 | 53 |
54 sandbox.appendChild( | 54 sandbox.appendChild( |
55 createDOM('div', {'id': 'host'}, | 55 createDOM('div', {'id': 'host'}, |
56 createShadowRoot( | 56 createShadowRoot( |
57 createDOM('style', {}, | 57 createDOM('style', {}, |
58 document.createTextNode('#child1.target ~ div { color: green }')
), | 58 document.createTextNode('#child1.target ~ div { color: green }')
), |
59 createDOM('div', {'id': 'child1'}, | 59 createDOM('div', {'id': 'child1'}, |
60 document.createTextNode('first div')), | 60 document.createTextNode('first div')), |
61 createDOM('div', {'id': 'child2'}, | 61 createDOM('div', {'id': 'child2'}, |
62 document.createTextNode('second div')), | 62 document.createTextNode('second div')), |
63 createDOM('div', {'id': 'child3'}, | 63 createDOM('div', {'id': 'child3'}, |
64 document.createTextNode('third div'))))); | 64 document.createTextNode('third div'))))); |
65 document.body.offsetLeft; | 65 document.body.offsetLeft; |
66 getNodeInTreeOfTrees('host/child1').className = 'target'; | 66 getNodeInComposedTree('host/child1').className = 'target'; |
67 colorShouldBe('host/child2', 'rgb(0, 128, 0)'); | 67 colorShouldBe('host/child2', 'rgb(0, 128, 0)'); |
68 colorShouldBe('host/child3', 'rgb(0, 128, 0)'); | 68 colorShouldBe('host/child3', 'rgb(0, 128, 0)'); |
69 | 69 |
70 cleanUp(); | 70 cleanUp(); |
71 | 71 |
72 // Test div:first-child under shadow-root. | 72 // Test div:first-child under shadow-root. |
73 sandbox.appendChild( | 73 sandbox.appendChild( |
74 createDOM('div', {'id': 'host'}, | 74 createDOM('div', {'id': 'host'}, |
75 createShadowRoot( | 75 createShadowRoot( |
76 createDOM('div', {'id': 'child1'}, | 76 createDOM('div', {'id': 'child1'}, |
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
191 document.createTextNode('last span'))))); | 191 document.createTextNode('last span'))))); |
192 | 192 |
193 colorShouldNotBe('host/child1', 'rgb(0, 128, 0)'); | 193 colorShouldNotBe('host/child1', 'rgb(0, 128, 0)'); |
194 colorShouldBe('host/child2', 'rgb(0, 128, 0)'); | 194 colorShouldBe('host/child2', 'rgb(0, 128, 0)'); |
195 colorShouldNotBe('host/child3', 'rgb(0, 128, 0)'); | 195 colorShouldNotBe('host/child3', 'rgb(0, 128, 0)'); |
196 | 196 |
197 cleanUp(); | 197 cleanUp(); |
198 | 198 |
199 </script> | 199 </script> |
200 </html> | 200 </html> |
OLD | NEW |