testing/web-platform/tests/css/cssom/computed-style-001.html
author Cosmin Sabou <csabou@mozilla.com>
Sat, 12 Jul 2025 09:18:08 +0300 (2 hours ago)
changeset 796290 5ad1f0c58c82bdfa2f42fed870bbe143465398d0
parent 511948 30da7e6aed454122aeab402a958d70ddc0ab5f81
permissions -rw-r--r--
Revert "Bug 1977019 - re-enable hw video decoding testing. r=media-playback-reviewers,jolin" for causing win mda failures on test_hw_video_decoding.html This reverts commit 158474bdc0cf585b701bc47921f0a7d84f7bb84d.
<!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>