// META: script=/resources/testdriver.js // META: script=/resources/testdriver-vendor.js // META: script=resources/font-test-utils.js // META: timeout=long 'use strict'; font_access_test(async t => { const iframe = document.createElement('iframe'); document.body.appendChild(iframe); const frameWindow = iframe.contentWindow; const frameDOMException = iframe.contentWindow.DOMException; iframe.remove(); await promise_rejects_dom( t, 'InvalidStateError', frameDOMException, frameWindow.queryLocalFonts()); }, 'queryLocalFonts() must return an error when called from a detached frame.'); font_access_test(async t => { const iframe = document.createElement('iframe'); document.body.appendChild(iframe); iframe.contentWindow.queryLocalFonts; iframe.remove(); // Call queryLocalFonts() in the main frame. This should keep the test running // long enough to catch any crash from the queryLocalFonts() call in the // removed iframe. await self.queryLocalFonts(); }, 'Detaching iframe while queryLocalFonts() settles.'); font_access_test(async t => { const iframe = document.createElement('iframe'); document.body.appendChild(iframe); const iframeFonts = await iframe.contentWindow.queryLocalFonts(); assert_greater_than_equal(iframeFonts.length, 1, 'Need a least one font'); const iframeFontData = iframeFonts[0]; const frameDOMException = iframe.contentWindow.DOMException; iframe.remove(); iframeFontData.blob(); }, 'FontData.blob() should not crash when called from a detached iframe.');