diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /comm/mailnews/compose/test/unit/test_expandMailingLists.js | |
parent | Initial commit. (diff) | |
download | thunderbird-upstream.tar.xz thunderbird-upstream.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'comm/mailnews/compose/test/unit/test_expandMailingLists.js')
-rw-r--r-- | comm/mailnews/compose/test/unit/test_expandMailingLists.js | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/comm/mailnews/compose/test/unit/test_expandMailingLists.js b/comm/mailnews/compose/test/unit/test_expandMailingLists.js new file mode 100644 index 0000000000..aa5998196f --- /dev/null +++ b/comm/mailnews/compose/test/unit/test_expandMailingLists.js @@ -0,0 +1,115 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ + +/** + * Tests nsMsgCompose expandMailingLists. + */ + +var MsgComposeContractID = "@mozilla.org/messengercompose/compose;1"; +var MsgComposeParamsContractID = + "@mozilla.org/messengercompose/composeparams;1"; +var MsgComposeFieldsContractID = + "@mozilla.org/messengercompose/composefields;1"; +var nsIMsgCompose = Ci.nsIMsgCompose; +var nsIMsgComposeParams = Ci.nsIMsgComposeParams; +var nsIMsgCompFields = Ci.nsIMsgCompFields; + +var { MailServices } = ChromeUtils.import( + "resource:///modules/MailServices.jsm" +); + +/** + * Helper to check population worked as expected. + * + * @param {string} aTo - Text in the To field. + * @param {string} aCheckTo - The expected To addresses (after possible list population). + */ +function checkPopulate(aTo, aCheckTo) { + let msgCompose = Cc[MsgComposeContractID].createInstance(nsIMsgCompose); + + // Set up some basic fields for compose. + let fields = Cc[MsgComposeFieldsContractID].createInstance(nsIMsgCompFields); + + fields.to = aTo; + + // Set up some params + let params = + Cc[MsgComposeParamsContractID].createInstance(nsIMsgComposeParams); + + params.composeFields = fields; + + msgCompose.initialize(params); + + msgCompose.expandMailingLists(); + equal(fields.to, aCheckTo); +} + +function run_test() { + loadABFile("data/listexpansion", kPABData.fileName); + + // XXX Getting all directories ensures we create all ABs because mailing + // lists need help initialising themselves + MailServices.ab.directories; + + // Test expansion of list with no description. + checkPopulate( + "simpson <simpson>", + 'Simpson <homer@example.com>, Marge <marge@example.com>, Bart <bart@foobar.invalid>, "lisa@example.com" <lisa@example.com>' + ); + + // Test expansion fo list with description. + checkPopulate( + "marge <marges own list>", + "Simpson <homer@example.com>, Marge <marge@example.com>" + ); + + // Special tests for bug 1287726: Lists in list. This is what the data looks like: + // 1) family (list) = parents (list) + kids (list). + // 2) parents (list) = homer + marge + parents (list recursion). + // 3) kids (list) = older-kids (list) + maggie. + // 4) older-kids (list) = bart + lisa. + // 5) bad-kids (list) = older-kids + bad-younger-kids (list). + // 6) bad-younger-kids (list) = maggie + bad-kids (list recursion). + checkPopulate( + "family <family>", + "Simpson <homer@example.com>, Marge <marge@example.com>, " + + '"lisa@example.com" <lisa@example.com>, Bart <bart@foobar.invalid>, Maggie <maggie@example.com>' + ); + checkPopulate( + "parents <parents>", + "Simpson <homer@example.com>, Marge <marge@example.com>" + ); + checkPopulate( + "kids <kids>", + '"lisa@example.com" <lisa@example.com>, Bart <bart@foobar.invalid>, ' + + "Maggie <maggie@example.com>" + ); + checkPopulate( + "older-kids <older-kids>", + '"lisa@example.com" <lisa@example.com>, Bart <bart@foobar.invalid>' + ); + checkPopulate( + "bad-kids <bad-kids>", + '"lisa@example.com" <lisa@example.com>, Bart <bart@foobar.invalid>, ' + + "Maggie <maggie@example.com>" + ); + checkPopulate( + "bad-younger-kids <bad-younger-kids>", + "Maggie <maggie@example.com>, " + + '"lisa@example.com" <lisa@example.com>, Bart <bart@foobar.invalid>' + ); + + // Test we don't mistake an email address for a list, with a few variations. + checkPopulate("Simpson <homer@example.com>", "Simpson <homer@example.com>"); + checkPopulate("simpson <homer@example.com>", "simpson <homer@example.com>"); + checkPopulate( + "simpson <homer@not-in-ab.invalid>", + "simpson <homer@not-in-ab.invalid>" + ); + + checkPopulate("Marge <marge@example.com>", "Marge <marge@example.com>"); + checkPopulate("marge <marge@example.com>", "marge <marge@example.com>"); + checkPopulate( + "marge <marge@not-in-ab.invalid>", + "marge <marge@not-in-ab.invalid>" + ); +} |