summaryrefslogtreecommitdiffstats
path: root/browser/components/translations/tests/browser/browser_translations_reader_mode.js
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/translations/tests/browser/browser_translations_reader_mode.js')
-rw-r--r--browser/components/translations/tests/browser/browser_translations_reader_mode.js115
1 files changed, 115 insertions, 0 deletions
diff --git a/browser/components/translations/tests/browser/browser_translations_reader_mode.js b/browser/components/translations/tests/browser/browser_translations_reader_mode.js
new file mode 100644
index 0000000000..d066257998
--- /dev/null
+++ b/browser/components/translations/tests/browser/browser_translations_reader_mode.js
@@ -0,0 +1,115 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"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.openTranslationsPanel({
+ 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();
+});