Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

/* Any copyright is dedicated to the Public Domain.
"use strict";
/* import-globals-from ../../../server/tests/browser/head.js */
// Tests that the markup localization works properly.
const { localizeMarkup } = require("resource://devtools/shared/l10n.js");
const HTML_NS = "http://www.w3.org/1999/xhtml";
add_task(async function () {
info("Check that the strings used for this test are still valid");
const STARTUP_L10N = new LocalizationHelper(
"devtools/client/locales/startup.properties"
);
const TOOLBOX_L10N = new LocalizationHelper(
"devtools/client/locales/toolbox.properties"
);
const str1 = STARTUP_L10N.getStr("inspector.label");
const str2 = STARTUP_L10N.getStr("inspector.accesskey");
const str3 = TOOLBOX_L10N.getStr("toolbox.defaultTitle");
ok(
str1 && str2 && str3,
"If this failed, strings should be updated in the test"
);
info("Create the test markup");
const div = document.createElementNS(HTML_NS, "div");
div.setAttribute(
"data-localization-bundle",
"devtools/client/locales/startup.properties"
);
const div0 = document.createElementNS(HTML_NS, "div");
div0.setAttribute("id", "d0");
div0.setAttribute("data-localization", "content=inspector.someInvalidKey");
div.appendChild(div0);
const div1 = document.createElementNS(HTML_NS, "div");
div1.setAttribute("id", "d1");
div1.setAttribute("data-localization", "content=inspector.label");
div.appendChild(div1);
div1.append("Text will disappear");
const div2 = document.createElementNS(HTML_NS, "div");
div2.setAttribute("id", "d2");
div2.setAttribute(
"data-localization",
"content=inspector.label;title=inspector.accesskey"
);
div.appendChild(div2);
const div3 = document.createElementNS(HTML_NS, "div");
div3.setAttribute("id", "d3");
div3.setAttribute(
"data-localization",
"content=inspector.label;title=inspector.accesskey"
);
div.appendChild(div3);
const div4 = document.createElementNS(HTML_NS, "div");
div4.setAttribute("id", "d4");
div4.setAttribute("data-localization", "aria-label=inspector.label");
div.appendChild(div4);
div4.append("Some content");
const toolboxDiv = document.createElementNS(HTML_NS, "div");
toolboxDiv.setAttribute(
"data-localization-bundle",
"devtools/client/locales/toolbox.properties"
);
div.appendChild(toolboxDiv);
const div5 = document.createElementNS(HTML_NS, "div");
div5.setAttribute("id", "d5");
div5.setAttribute("data-localization", "content=toolbox.defaultTitle");
toolboxDiv.appendChild(div5);
info("Use localization helper to localize the test markup");
localizeMarkup(div);
is(div1.innerHTML, str1, "The content of #d1 is localized");
is(div2.innerHTML, str1, "The content of #d2 is localized");
is(div2.getAttribute("title"), str2, "The title of #d2 is localized");
is(div3.innerHTML, str1, "The content of #d3 is localized");
is(div3.getAttribute("title"), str2, "The title of #d3 is localized");
is(div4.innerHTML, "Some content", "The content of #d4 is not replaced");
is(
div4.getAttribute("aria-label"),
str1,
"The aria-label of #d4 is localized"
);
is(
div5.innerHTML,
str3,
"The content of #d5 is localized with another bundle"
);
});