From 6bf0a5cb5034a7e684dcc3500e841785237ce2dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 19:32:43 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- comm/mail/test/browser/junk-commands/browser.ini | 11 +++ .../browser/junk-commands/browser_junkCommands.js | 105 +++++++++++++++++++++ 2 files changed, 116 insertions(+) create mode 100644 comm/mail/test/browser/junk-commands/browser.ini create mode 100644 comm/mail/test/browser/junk-commands/browser_junkCommands.js (limited to 'comm/mail/test/browser/junk-commands') diff --git a/comm/mail/test/browser/junk-commands/browser.ini b/comm/mail/test/browser/junk-commands/browser.ini new file mode 100644 index 0000000000..9366f31ed2 --- /dev/null +++ b/comm/mail/test/browser/junk-commands/browser.ini @@ -0,0 +1,11 @@ +[DEFAULT] +prefs = + mail.provider.suppress_dialog_on_startup=true + mail.spotlight.firstRunDone=true + mail.winsearch.firstRunDone=true + mailnews.start_page.override_url=about:blank + mailnews.start_page.url=about:blank + datareporting.policy.dataSubmissionPolicyBypassNotification=true +subsuite = thunderbird + +[browser_junkCommands.js] diff --git a/comm/mail/test/browser/junk-commands/browser_junkCommands.js b/comm/mail/test/browser/junk-commands/browser_junkCommands.js new file mode 100644 index 0000000000..498395ff75 --- /dev/null +++ b/comm/mail/test/browser/junk-commands/browser_junkCommands.js @@ -0,0 +1,105 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +var { + be_in_folder, + create_folder, + make_message_sets_in_folders, + select_click_row, + select_none, + select_shift_click_row, +} = ChromeUtils.import( + "resource://testing-common/mozmill/FolderDisplayHelpers.jsm" +); +var { delete_mail_marked_as_junk, mark_selected_messages_as_junk } = + ChromeUtils.import("resource://testing-common/mozmill/JunkHelpers.jsm"); + +// One folder's enough +var folder = null; + +add_setup(async function () { + folder = await create_folder("JunkCommandsA"); + await make_message_sets_in_folders([folder], [{ count: 30 }]); +}); + +/** + * The number of messages to mark as junk and expect to be deleted. + */ +var NUM_MESSAGES_TO_JUNK = 8; + +/** + * Helper to check whether a folder has the right number of messages. + * + * @param aFolder the folder to check + * @param aNumMessages the number of messages the folder should contain. + */ +function _assert_folder_total_messages(aFolder, aNumMessages) { + let curMessages = aFolder.getTotalMessages(false); + if (curMessages != aNumMessages) { + throw new Error( + "The folder " + + aFolder.prettyName + + " should have " + + aNumMessages + + " messages, but actually has " + + curMessages + + " messages." + ); + } +} + +/** + * Test deleting junk messages with no messages marked as junk. + */ +add_task(async function test_delete_no_junk_messages() { + let initialNumMessages = folder.getTotalMessages(false); + await be_in_folder(folder); + select_none(); + await delete_mail_marked_as_junk(0); + // Check if we still have the same number of messages + _assert_folder_total_messages(folder, initialNumMessages); +}); + +/** + * Test deleting junk messages with some messages marked as junk. + */ +add_task(async function test_delete_junk_messages() { + let initialNumMessages = folder.getTotalMessages(false); + await be_in_folder(folder); + select_click_row(1); + let selectedMessages = select_shift_click_row(NUM_MESSAGES_TO_JUNK); + Assert.equal( + selectedMessages.length, + NUM_MESSAGES_TO_JUNK, + `should have selected correct number of msgs` + ); + // Mark these messages as junk + mark_selected_messages_as_junk(); + // Now delete junk mail + await delete_mail_marked_as_junk(NUM_MESSAGES_TO_JUNK); + // Check that we have the right number of messages left + _assert_folder_total_messages( + folder, + initialNumMessages - NUM_MESSAGES_TO_JUNK + ); + // Check that none of the message keys exist any more + let db = folder.getDBFolderInfoAndDB({}); + for (let msgHdr of selectedMessages) { + let key = msgHdr.messageKey; + if (db.containsKey(key)) { + throw new Error( + "The database shouldn't contain key " + key + ", but does." + ); + } + } + + Assert.report( + false, + undefined, + undefined, + "Test ran to completion successfully" + ); +}); -- cgit v1.2.3