summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/paint-timing/fcp-only/buffered-flag.window.js
blob: 5910b6881fb34486a24348c35eae84efe291469a (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
setup({"hide_test_state": true});
async_test(t => {
  assert_implements(window.PerformancePaintTiming, "Paint Timing isn't supported.");
  // First observer creates a second one in the callback to ensure the entry has been dispatched
  // by the time the second observer begins observing.
  new PerformanceObserver(entries => {
    const entry_seen = entries.getEntriesByName('first-contentful-paint').length > 0;
    // Abort if we have not yet received the entry.
    if (!entry_seen)
      return;

    // Second observer requires 'buffered: true' to see the entry.
    new PerformanceObserver(t.step_func_done(list => {
        const fcp = list.getEntriesByName('first-contentful-paint');
        assert_equals(fcp.length, 1, 'Should have an fcp entry');
        const entry = fcp[0];
        assert_equals(entry.entryType, 'paint');
      })).observe({'type': 'paint', buffered: true});
  }).observe({'entryTypes': ['paint']});
  // Trigger the first contentful paint entry.
  const img = document.createElement("img");
  img.src = "../resources/circles.png";
  document.body.appendChild(img);
}, "PerformanceObserver with buffered flag sees previous FCP entry.");