Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / third_party / WebKit / LayoutTests / fast / dom / css-dom-read-2.html
blobe8c96b3b07814de88aabb455cb8f3a1be4577adc
1 <html>
2 <head>
3 <style id="style">@import url("fancyfonts.css") screen;
4 @media print {
5 body { font-size: 10pt }
7 @media screen {
8 body { font-size: 13px }
10 @media screen, print {
11 body { line-height: 1.2 }
13 .one {display: block;}
14 .two {display: inline;}
15 .three {display: list-item; list-style-type: square; margin-left: 3em;}
16 .four {display: none; color: red;}
17 I {display: block;}
18 </style>
19 </head>
20 <body onload="runTests();">
21 <script>
22 function dumpRuleList(cssRules)
24 var s = '';
26 var i;
27 for (i = 0; i < cssRules.length; i++) {
28 rule = cssRules.item(i);
30 switch (rule.type) {
31 case CSSRule.IMPORT_RULE:
32 s += '@import url("' + rule.href + '") ' + rule.media.mediaText;
33 s += ';\n';
34 break;
35 case CSSRule.STYLE_RULE:
36 s += rule.selectorText + ' { ';
38 style = rule.style;
39 for (j = 0; j < style.length; j++) {
40 s += style.item(j) + ': ' + style.getPropertyValue(style.item(j))+ '; ';
42 s += '} \n';
43 break;
44 case CSSRule.MEDIA_RULE:
45 s += '@media ' + rule.media.mediaText + ' {\n';
46 s += ' ' + dumpRuleList(rule.cssRules);
47 s += '}\n';
48 break;
49 case CSSRule.PAGE_RULE:
50 s += '@page ';
51 break;
56 return s;
59 function debug(s) {
60 console = document.getElementById('console');
61 li = document.createElement('li');
62 console.appendChild(li);
63 pre = document.createElement('pre');
64 li.appendChild(pre);
65 t = document.createTextNode(s + '\n');
66 pre.appendChild(t);
69 function runTests() {
70 if (window.testRunner)
71 testRunner.dumpAsText();
73 originalStyle = document.getElementById('style').firstChild.nodeValue;
74 debug(originalStyle);
76 styleSheet = document.styleSheets.item(0)
77 s = dumpRuleList(styleSheet.cssRules);
78 debug(s);
80 s = ""
81 for (i = 0; i < styleSheet.cssRules.length; i++) {
82 rule = styleSheet.cssRules.item(i);
84 s += rule.cssText + '\n';
86 debug(s);
88 </script>
89 This tests different ways of deserializing css stylesheets. The first item below is the style as specified in the document. The second is serialized using the different rule accessors. The third just uses rule.cssText. If the test is successful, all three should be the same.
90 <ul id="console">
91 </ul>
92 </body>
93 </html>