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.");