summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/long-animation-frame/tentative/loaf-script-nested-callback.html
blob: 8d1304fc802921b203996b5c6e7ada2ea85681ac (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
<!DOCTYPE HTML>
<meta charset=utf-8>
<title>Long Animation Frame Timing: nested scripts</title>
<meta name="timeout" content="long">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/utils.js"></script>
<script src="resources/utils.js"></script>

<body>
<h1>Long Animation Frame: nested scripts</h1>
<div id="log"></div>
<div id="dummy"></div>
<script>
promise_test(async t => {
  const [entry, script] = await expect_long_frame_with_script(t => {
    const script_element = document.createElement("script");
    script_element.async = true;
    script_element.src = "resources/loaf-after-callback.js";
    t.add_cleanup(() => script_element.remove());
    document.body.appendChild(script_element);
  }, script =>
    script.invoker === new URL("resources/loaf-after-callback.js", location.href).href,
    t);
  assert_greater_than_equal(script.duration, very_long_frame_duration);
}, "a callback inside a script block should not mask LoAFs that come afterwards")

promise_test(async t => {
  const [entry, script] = await expect_long_frame_with_script(t => {
    const script_element = document.createElement("script");
    script_element.async = true;
    script_element.src = "resources/loaf-in-microtask-after-callback.js";
    t.add_cleanup(() => script_element.remove());
    document.body.appendChild(script_element);
  }, script =>
    script.invoker === new URL("resources/loaf-in-microtask-after-callback.js", location.href).href,
    t);
  assert_greater_than_equal(script.duration, very_long_frame_duration);
}, "a callback inside a script block should not mask LoAFs in a microtask")
</script>
</body>