summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/cssom/computed-style-001.html
blob: e487981e305df3b76f6cc45ea12bc0bf3349c2a7 (plain)
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
<!DOCTYPE html>
<html>
 <head>
  <title>CSS Test: getComputedStyle</title>
  <link rel="author" title="Bear Travis" href="mailto:betravis@adobe.com">
  <link rel="help" href="http://www.w3.org/TR/cssom-1/#extensions-to-the-window-interface">
  <link rel="help" href="http://www.w3.org/TR/cssom-1/#the-cssstyledeclaration-interface">
  <link rel="help" href="http://www.w3.org/TR/cssom-1/#resolved-values">
  <meta name="flags" content="dom">
  <meta name="assert" content="getComputedStyle returns a readonly CSSStyleDeclaration with resolved values">
  <script src="/resources/testharness.js" type="text/javascript"></script>
  <script src="/resources/testharnessreport.js" type="text/javascript"></script>
  <style>
    #outside {
        width: 200px;
        height: 200px;
    }
    #outside div {
        font-size: 100px;
    }
    #inside {
        width: 50%;
        height: 100px;
    }
  </style>
 </head>
 <body>
 <noscript>Test not run - javascript required.</noscript>
 <div id="log"></div>
 <div id="outside"><div id="inside"></div></div>
 <script type="text/javascript">
    var outer = document.getElementById("outside");
    var inner = document.getElementById("inside");
    var innerStyle;

    // do not allow modifications to a computed CSSStyleDeclaration
    test(function() {
        innerStyle = window.getComputedStyle(inner);
        assert_throws_dom(  "NO_MODIFICATION_ALLOWED_ERR",
                        function() { innerStyle.cssText = "color: blue;"; },
                        "do not allow setting cssText on a readonly CSSStyleDeclaration");
        assert_throws_dom(  "NO_MODIFICATION_ALLOWED_ERR",
                        function() { innerStyle.setProperty("color", "blue"); },
                        "do not allow calling setProperty on a readonly CSSStyleDeclaration");
        assert_throws_dom(  "NO_MODIFICATION_ALLOWED_ERR",
                        function() { innerStyle.color = "blue"; },
                        "do not allow setting a property on a readonly CSSStyleDeclaration");
    }, "read_only");

    // Directly set properties are resolved
    test(function() {
        assert_equals(innerStyle.getPropertyValue("height"), "100px");
    }, "property_values");

    // Inherited properties are resolved
    test(function() {
        assert_equals(innerStyle.getPropertyValue("font-size"), "100px");
    }, "inherited_property_values");

    // Relative properties are resolved
    test(function() {
        assert_equals(innerStyle.getPropertyValue("width"), "100px");
    }, "relative_property_values");
 </script>
 </body>
</html>