/* Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ /* eslint-disable mozilla/no-arbitrary-setTimeout */ const ROOTURI = "http://mochi.test:8888/browser/browser/base/content/test/favicons/"; const ICON = "moz.png"; const DATAURL = ""; let iconDiscoveryTests = [ { text: "rel icon discovered", icons: [{}], }, { text: "rel may contain additional rels separated by spaces", icons: [{ rel: "abcdefg icon qwerty" }], }, { text: "rel is case insensitive", icons: [{ rel: "ICON" }], }, { text: "rel shortcut-icon not discovered", expectedIcon: ROOTURI + ICON, icons: [ // We will prefer the later icon if detected {}, { rel: "shortcut-icon", href: "nothere.png" }, ], }, { text: "relative href works", icons: [{ href: "moz.png" }], }, { text: "404'd icon is removed properly", pass: false, icons: [{ href: "notthere.png" }], }, { text: "data: URIs work", icons: [{ href: DATAURL, type: "image/x-icon" }], }, { text: "type may have optional parameters (RFC2046)", icons: [{ type: "image/png; charset=utf-8" }], }, { text: "apple-touch-icon discovered", richIcon: true, icons: [{ rel: "apple-touch-icon" }], }, { text: "apple-touch-icon-precomposed discovered", richIcon: true, icons: [{ rel: "apple-touch-icon-precomposed" }], }, { text: "fluid-icon discovered", richIcon: true, icons: [{ rel: "fluid-icon" }], }, { text: "unknown icon not discovered", expectedIcon: ROOTURI + ICON, richIcon: true, icons: [ // We will prefer the larger icon if detected { rel: "apple-touch-icon", sizes: "32x32" }, { rel: "unknown-icon", sizes: "128x128", href: "notthere.png" }, ], }, ]; add_task(async function () { let url = ROOTURI + "discovery.html"; let tab = await BrowserTestUtils.openNewForegroundTab(gBrowser, url); for (let testCase of iconDiscoveryTests) { info(`Running test "${testCase.text}"`); if (testCase.pass === undefined) { testCase.pass = true; } if (testCase.icons.length > 1 && !testCase.expectedIcon) { ok(false, "Invalid test data, missing expectedIcon"); continue; } let expectedIcon = testCase.expectedIcon || testCase.icons[0].href || ICON; expectedIcon = new URL(expectedIcon, ROOTURI).href; let iconPromise = waitForFaviconMessage(!testCase.richIcon, expectedIcon); await SpecialPowers.spawn( gBrowser.selectedBrowser, [[testCase.icons, ROOTURI + ICON]], ([icons, defaultIcon]) => { let doc = content.document; let head = doc.head; for (let icon of icons) { let link = doc.createElement("link"); link.rel = icon.rel || "icon"; link.href = icon.href || defaultIcon; link.type = icon.type || "image/png"; if (icon.sizes) { link.sizes = icon.sizes; } head.appendChild(link); } } ); try { let { iconURL } = await iconPromise; ok(testCase.pass, testCase.text); is(iconURL, expectedIcon, "Should have seen the expected icon."); } catch (e) { ok(!testCase.pass, testCase.text); } await SpecialPowers.spawn(gBrowser.selectedBrowser, [], () => { let links = content.document.querySelectorAll("link"); for (let link of links) { link.remove(); } }); } BrowserTestUtils.removeTab(tab); });