blob: 549d04c5c0aa13dc38e4be1d71d7a8f7d62dc93d (
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
|
<!doctype html>
<meta charset="utf-8">
<title>
Test for bug 1519371: We don't reframe for changes that affect our containing
block status unless whether we're a containing block really changed.
</title>
<link rel="author" href="mailto:emilio@crisal.io" title="Emilio Cobos Álvarez">
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<div id="content"></div>
<script>
SimpleTest.waitForExplicitFinish();
const utils = SpecialPowers.getDOMWindowUtils(window);
function expectReframe(shouldHaveReframed, callback) {
document.documentElement.offsetTop;
const previousConstructCount = utils.framesConstructed;
const previousRestyleGeneration = utils.restyleGeneration;
callback();
document.documentElement.offsetTop;
isnot(previousRestyleGeneration, utils.restyleGeneration,
"We should have restyled");
(shouldHaveReframed ? isnot : is)(previousConstructCount,
utils.framesConstructed,
`We should ${shouldHaveReframed ? "" : "not"} have reframed`);
}
const content = document.getElementById("content");
// Without fixed-pos descendants, we should not reframe.
expectReframe(false, () => {
content.style.transform = "scale(1)";
});
content.style.transform = "";
content.innerHTML = `<div style="position: fixed"></div>`;
// With fixed-pos descendants, got to reframe.
expectReframe(true, () => {
content.style.transform = "scale(1)";
});
// If our containing-block-ness didn't change, we should not need to reframe.
expectReframe(false, () => {
content.style.willChange = "transform";
});
// If it does change, we need to reframe.
expectReframe(true, () => {
content.style.willChange = "";
content.style.transform = "";
});
SimpleTest.finish();
</script>
|