mirror of
https://github.com/python/cpython.git
synced 2025-11-03 03:22:27 +00:00
gh-65495: Use lowercase mail from and rcpt to in smtplib.SMTP (#107019)
Use lowercase `mail from` and `rcpt to` in `smtplib.SMTP` SMTP commands are case-insensitive. `smtplib` uses lowercase commands, however it writes `mail FROM` and `rcpt TO`, lacking consistency.
This commit is contained in:
parent
d228825e08
commit
3782def5a2
3 changed files with 17 additions and 2 deletions
|
|
@ -831,6 +831,7 @@ class SimSMTPChannel(smtpd.SMTPChannel):
|
|||
def __init__(self, extra_features, *args, **kw):
|
||||
self._extrafeatures = ''.join(
|
||||
[ "250-{0}\r\n".format(x) for x in extra_features ])
|
||||
self.all_received_lines = []
|
||||
super(SimSMTPChannel, self).__init__(*args, **kw)
|
||||
|
||||
# AUTH related stuff. It would be nice if support for this were in smtpd.
|
||||
|
|
@ -845,6 +846,7 @@ class SimSMTPChannel(smtpd.SMTPChannel):
|
|||
self.smtp_state = self.COMMAND
|
||||
self.push('%s %s' % (e.smtp_code, e.smtp_error))
|
||||
return
|
||||
self.all_received_lines.append(self.received_lines)
|
||||
super().found_terminator()
|
||||
|
||||
|
||||
|
|
@ -1349,6 +1351,18 @@ class SMTPSimTests(unittest.TestCase):
|
|||
self.assertEqual(self.serv._addresses['from'], 'michael@example.com')
|
||||
self.assertEqual(self.serv._addresses['tos'], ['rene@example.com'])
|
||||
|
||||
def test_lowercase_mail_from_rcpt_to(self):
|
||||
m = 'A test message'
|
||||
smtp = smtplib.SMTP(
|
||||
HOST, self.port, local_hostname='localhost',
|
||||
timeout=support.LOOPBACK_TIMEOUT)
|
||||
self.addCleanup(smtp.close)
|
||||
|
||||
smtp.sendmail('John', 'Sally', m)
|
||||
|
||||
self.assertIn(['mail from:<John> size=14'], self.serv._SMTPchannel.all_received_lines)
|
||||
self.assertIn(['rcpt to:<Sally>'], self.serv._SMTPchannel.all_received_lines)
|
||||
|
||||
|
||||
class SimSMTPUTF8Server(SimSMTPServer):
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue