summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/flexbox/test/browser_flexbox_item_outline_has_correct_layout.js
blob: e81d6f56776be542e9899e7fb82c737614b61b84 (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
/* Any copyright is dedicated to the Public Domain.
 http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

// Test that the flex item outline has a correct layout. This outline is built using css
// grid under the hood to position everything. So we want to check that the template for
// this grid has been correctly generated depending on the item that is currently
// selected.

const TEST_URI = URL_ROOT + "doc_flexbox_specific_cases.html";

const TEST_DATA = [
  {
    selector: ".shrinking .item",
    expectedGridTemplate:
      "[basis-start final-start] 300fr [final-end delta-start] " +
      "200fr [basis-end delta-end]",
  },
  {
    selector: ".shrinking.is-clamped .item",
    expectedGridTemplate:
      "[basis-start final-start] 300fr [delta-start] " +
      "50fr [final-end min] 150fr [basis-end delta-end]",
  },
  {
    selector: ".growing .item",
    expectedGridTemplate:
      "[basis-start final-start] 200fr [basis-end delta-start] " +
      "100fr [final-end delta-end]",
  },
  {
    selector: ".growing.is-clamped .item",
    expectedGridTemplate:
      "[basis-start final-start] 200fr [basis-end delta-start] " +
      "50fr [final-end max] 50fr [delta-end]",
  },
  {
    selector: "#wanted-to-shrink-more-than-basis div:first-child",
    expectedGridTemplate:
      "[delta-start] 63fr [basis-start final-start] " +
      "60fr [final-end min] 140fr [basis-end delta-end]",
  },
];

add_task(async function () {
  await addTab(TEST_URI);
  const { inspector, flexboxInspector } = await openLayoutView();
  const { document: doc } = flexboxInspector;

  for (const { selector, expectedGridTemplate } of TEST_DATA) {
    info(
      `Checking the grid template for the flex item outline for ${selector}`
    );

    await selectNode(selector, inspector);
    await waitUntil(() => {
      const flexOutline = doc.querySelector(".flex-outline");
      return (
        flexOutline &&
        flexOutline.style.gridTemplateColumns === expectedGridTemplate
      );
    });

    ok(true, "Grid template is correct");
  }
});