summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/chrome/test_css-logic-media-queries.html
blob: feaf0f5d39cec89f9287ffbbd4892c5b7a7a8d30 (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
<!DOCTYPE HTML>
<html>
<!--
Test that css-logic handles media-queries correctly
-->
<head>
  <meta charset="utf-8">
  <title>Test css-logic media-queries</title>
  <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css">
  <style>
    div {
      width: 1000px;
      height: 100px;
      background-color: #f00;
    }

    @media screen and (min-width: 1px) {
      div {
        width: 200px;
      }
    }
  </style>
</head>
<body>
  <div></div>
  <script type="application/javascript">
  "use strict";

  window.onload = function() {
    const {require} = ChromeUtils.importESModule("resource://devtools/shared/loader/Loader.sys.mjs");
    const {CssLogic} = require("devtools/server/actors/inspector/css-logic");

    SimpleTest.waitForExplicitFinish();

    const div = document.querySelector("div");
    const cssLogic = new CssLogic();
    cssLogic.highlight(div);
    cssLogic.processMatchedSelectors();

    const _strings = Services.strings
      .createBundle("chrome://devtools-shared/locale/styleinspector.properties");

    const inline = _strings.GetStringFromName("rule.sourceInline");

    const source1 = inline + ":2";
    const source2 = inline + ":9 @media screen and (min-width: 1px)";
    is(cssLogic._matchedRules[0][0].source, source1,
      "rule.source gives correct output for rule 1");
    is(cssLogic._matchedRules[1][0].source, source2,
      "rule.source gives correct output for rule 2");

    SimpleTest.finish();
  };
  </script>
</body>
</html>