Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Errors

/* Any copyright is dedicated to the Public Domain.
"use strict";
/**
* Tests that the translations button becomes hidden when entering reader mode.
*/
add_task(async function test_translations_button_hidden_in_reader_mode() {
const { cleanup, runInPage } = await loadTestPage({
page: SPANISH_PAGE_URL,
languagePairs: LANGUAGE_PAIRS,
});
await FullPageTranslationsTestUtils.assertTranslationsButton(
{ button: true },
"The translations button is visible."
);
await FullPageTranslationsTestUtils.assertPageIsUntranslated(runInPage);
await toggleReaderMode();
await FullPageTranslationsTestUtils.assertTranslationsButton(
{ button: false },
"The translations button is now hidden in reader mode."
);
await runInPage(async TranslationsTest => {
const { getH1 } = TranslationsTest.getSelectors();
await TranslationsTest.assertTranslationResult(
"The page's H1 is now the reader-mode header",
getH1,
"Translations Test"
);
});
await runInPage(async TranslationsTest => {
const { getLastParagraph } = TranslationsTest.getSelectors();
await TranslationsTest.assertTranslationResult(
"The page's last paragraph is in Spanish.",
getLastParagraph,
"— Pues, aunque mováis más brazos que los del gigante Briareo, me lo habéis de pagar."
);
});
await toggleReaderMode();
await FullPageTranslationsTestUtils.assertTranslationsButton(
{ button: true },
"The translations button is visible again outside of reader mode."
);
await FullPageTranslationsTestUtils.assertPageIsUntranslated(runInPage);
await cleanup();
});
/**
* Tests that translations persist when entering reader mode after translating.
*/
add_task(async function test_translations_persist_in_reader_mode() {
const { cleanup, resolveDownloads, runInPage } = await loadTestPage({
page: SPANISH_PAGE_URL,
languagePairs: LANGUAGE_PAIRS,
});
await FullPageTranslationsTestUtils.assertTranslationsButton(
{ button: true },
"The translations button is visible."
);
await FullPageTranslationsTestUtils.assertPageIsUntranslated(runInPage);
await FullPageTranslationsTestUtils.openPanel({
onOpenPanel: FullPageTranslationsTestUtils.assertPanelViewDefault,
});
await FullPageTranslationsTestUtils.clickTranslateButton({
downloadHandler: resolveDownloads,
});
await FullPageTranslationsTestUtils.assertPageIsTranslated(
"es",
"en",
runInPage
);
await toggleReaderMode();
await runInPage(async TranslationsTest => {
const { getH1 } = TranslationsTest.getSelectors();
await TranslationsTest.assertTranslationResult(
"The page's H1 is now the translated reader-mode header",
getH1,
"TRANSLATIONS TEST [es to en, html]"
);
});
await runInPage(async TranslationsTest => {
const { getLastParagraph } = TranslationsTest.getSelectors();
await TranslationsTest.assertTranslationResult(
"The page's last paragraph is in Spanish.",
getLastParagraph,
"— PUES, AUNQUE MOVÁIS MÁS BRAZOS QUE LOS DEL GIGANTE BRIAREO, ME LO HABÉIS DE PAGAR. [es to en, html]"
);
});
await FullPageTranslationsTestUtils.assertTranslationsButton(
{ button: false },
"The translations button is now hidden in reader mode."
);
await cleanup();
});