summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/chrome/inactive-property-helper/positioned.mjs
blob: b9ebe5aaee28b64068879d021217c6a642e81f24 (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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

// InactivePropertyHelper positioned elements test cases.

// These are the properties we care about, those that are inactive when the element isn't
// positioned.
const PROPERTIES = [
  { property: "z-index", value: "2" },
  { property: "top", value: "20px" },
  { property: "right", value: "20px" },
  { property: "bottom", value: "20px" },
  { property: "left", value: "20px" },
];

// These are all of the different position values and whether the above properties are
// active or not for each.
const POSITIONS = [
  { position: "unset", isActive: false },
  { position: "initial", isActive: false },
  { position: "inherit", isActive: false },
  { position: "static", isActive: false },
  { position: "absolute", isActive: true },
  { position: "relative", isActive: true },
  { position: "fixed", isActive: true },
  { position: "sticky", isActive: true },
];

function makeTestCase(property, value, position, isActive) {
  return {
    info: `${property} is ${
      isActive ? "" : "in"
    }active when position is ${position}`,
    property,
    tagName: "div",
    rules: [`div { ${property}: ${value}; position: ${position}; }`],
    isActive,
  };
}

// Make the test cases for all the combinations of PROPERTIES and POSITIONS
const mainTests = [];

for (const { property, value } of PROPERTIES) {
  for (const { position, isActive } of POSITIONS) {
    mainTests.push(makeTestCase(property, value, position, isActive));
  }
}

// Add a few test cases to check that z-index actually works inside grids and flexboxes.
mainTests.push({
  info:
    "z-index is active even on unpositioned elements if they are grid items",
  property: "z-index",
  createTestElement: rootNode => {
    const container = document.createElement("div");
    const element = document.createElement("span");
    container.append(element);
    rootNode.append(container);
    return element;
  },
  rules: ["div { display: grid; }", "span { z-index: 3; }"],
  ruleIndex: 1,
  isActive: true,
});

mainTests.push({
  info:
    "z-index is active even on unpositioned elements if they are flex items",
  property: "z-index",
  createTestElement: rootNode => {
    const container = document.createElement("div");
    const element = document.createElement("span");
    container.append(element);
    rootNode.append(container);
    return element;
  },
  rules: ["div { display: flex; }", "span { z-index: 3; }"],
  ruleIndex: 1,
  isActive: true,
});

export default mainTests;