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