# HG changeset patch # User Mads Kiilerich # Date 2020-08-18 19:36:26 # Node ID 9c408c0f1c9b35f48207a58581016bf30d305752 # Parent 2864cff1f12a0732a5b1dbf703a7e0d664168a69 rcmail: pass smtplib.SMTP.sendmail to_addrs as list Passing it as a set worked ... but is apparently wrong. The documentation states it has to be a "list of addresses". Pytype warned: File "kallithea/lib/rcmail/smtp_mailer.py", line 99, in send: Function SMTP.sendmail was called with the wrong arguments [wrong-arg-types] Expected: (self, from_addr, to_addrs: Union[Sequence[str], str], ...) Actually passed: (self, from_addr, to_addrs: set, ...) diff --git a/kallithea/lib/rcmail/smtp_mailer.py b/kallithea/lib/rcmail/smtp_mailer.py --- a/kallithea/lib/rcmail/smtp_mailer.py +++ b/kallithea/lib/rcmail/smtp_mailer.py @@ -96,7 +96,7 @@ class SmtpMailer(object): if self.user and self.passwd: smtp_serv.login(self.user, self.passwd) - smtp_serv.sendmail(msg.sender, msg.send_to, raw_msg.as_string()) + smtp_serv.sendmail(msg.sender, list(msg.send_to), raw_msg.as_string()) logging.info('MAIL SENT TO: %s' % recipients) try: diff --git a/kallithea/tests/other/test_mail.py b/kallithea/tests/other/test_mail.py --- a/kallithea/tests/other/test_mail.py +++ b/kallithea/tests/other/test_mail.py @@ -21,9 +21,8 @@ class smtplib_mock(object): def sendmail(self, sender, dest, msg): smtplib_mock.lastsender = sender - smtplib_mock.lastdest = dest + smtplib_mock.lastdest = set(dest) smtplib_mock.lastmsg = msg - pass @mock.patch('kallithea.lib.rcmail.smtp_mailer.smtplib', smtplib_mock)