Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

/* Any copyright is dedicated to the Public Domain.
"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");
}
});