AppPkg/Applications/Python: Add Python 2.7.2 sources since the release of Python 2.7.3 made them unavailable from the python.org web site.
These files are a subset of the python-2.7.2.tgz distribution from python.org. Changed files from PyMod-2.7.2 have been copied into the corresponding directories of this tree, replacing the original files in the distribution. Signed-off-by: daryl.mcdaniel@intel.com git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13197 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
257
AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rfc822.py
Normal file
257
AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rfc822.py
Normal file
@ -0,0 +1,257 @@
|
||||
import unittest
|
||||
from test import test_support
|
||||
|
||||
rfc822 = test_support.import_module("rfc822", deprecated=True)
|
||||
|
||||
try:
|
||||
from cStringIO import StringIO
|
||||
except ImportError:
|
||||
from StringIO import StringIO
|
||||
|
||||
|
||||
class MessageTestCase(unittest.TestCase):
|
||||
def create_message(self, msg):
|
||||
return rfc822.Message(StringIO(msg))
|
||||
|
||||
def test_get(self):
|
||||
msg = self.create_message(
|
||||
'To: "last, first" <userid@foo.net>\n\ntest\n')
|
||||
self.assertTrue(msg.get("to") == '"last, first" <userid@foo.net>')
|
||||
self.assertTrue(msg.get("TO") == '"last, first" <userid@foo.net>')
|
||||
self.assertTrue(msg.get("No-Such-Header") is None)
|
||||
self.assertTrue(msg.get("No-Such-Header", "No-Such-Value")
|
||||
== "No-Such-Value")
|
||||
|
||||
def test_setdefault(self):
|
||||
msg = self.create_message(
|
||||
'To: "last, first" <userid@foo.net>\n\ntest\n')
|
||||
self.assertTrue(not msg.has_key("New-Header"))
|
||||
self.assertTrue(msg.setdefault("New-Header", "New-Value") == "New-Value")
|
||||
self.assertTrue(msg.setdefault("New-Header", "Different-Value")
|
||||
== "New-Value")
|
||||
self.assertTrue(msg["new-header"] == "New-Value")
|
||||
|
||||
self.assertTrue(msg.setdefault("Another-Header") == "")
|
||||
self.assertTrue(msg["another-header"] == "")
|
||||
|
||||
def check(self, msg, results):
|
||||
"""Check addresses and the date."""
|
||||
m = self.create_message(msg)
|
||||
i = 0
|
||||
for n, a in m.getaddrlist('to') + m.getaddrlist('cc'):
|
||||
try:
|
||||
mn, ma = results[i][0], results[i][1]
|
||||
except IndexError:
|
||||
print 'extra parsed address:', repr(n), repr(a)
|
||||
continue
|
||||
i = i + 1
|
||||
self.assertEqual(mn, n,
|
||||
"Un-expected name: %r != %r" % (mn, n))
|
||||
self.assertEqual(ma, a,
|
||||
"Un-expected address: %r != %r" % (ma, a))
|
||||
if mn == n and ma == a:
|
||||
pass
|
||||
else:
|
||||
print 'not found:', repr(n), repr(a)
|
||||
|
||||
out = m.getdate('date')
|
||||
if out:
|
||||
self.assertEqual(out,
|
||||
(1999, 1, 13, 23, 57, 35, 0, 1, 0),
|
||||
"date conversion failed")
|
||||
|
||||
|
||||
# Note: all test cases must have the same date (in various formats),
|
||||
# or no date!
|
||||
|
||||
def test_basic(self):
|
||||
self.check(
|
||||
'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'
|
||||
'From: Guido van Rossum <guido@CNRI.Reston.VA.US>\n'
|
||||
'To: "Guido van\n'
|
||||
'\t : Rossum" <guido@python.org>\n'
|
||||
'Subject: test2\n'
|
||||
'\n'
|
||||
'test2\n',
|
||||
[('Guido van\n\t : Rossum', 'guido@python.org')])
|
||||
|
||||
self.check(
|
||||
'From: Barry <bwarsaw@python.org\n'
|
||||
'To: guido@python.org (Guido: the Barbarian)\n'
|
||||
'Subject: nonsense\n'
|
||||
'Date: Wednesday, January 13 1999 23:57:35 -0500\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('Guido: the Barbarian', 'guido@python.org')])
|
||||
|
||||
self.check(
|
||||
'From: Barry <bwarsaw@python.org\n'
|
||||
'To: guido@python.org (Guido: the Barbarian)\n'
|
||||
'Cc: "Guido: the Madman" <guido@python.org>\n'
|
||||
'Date: 13-Jan-1999 23:57:35 EST\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('Guido: the Barbarian', 'guido@python.org'),
|
||||
('Guido: the Madman', 'guido@python.org')
|
||||
])
|
||||
|
||||
self.check(
|
||||
'To: "The monster with\n'
|
||||
' the very long name: Guido" <guido@python.org>\n'
|
||||
'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('The monster with\n the very long name: Guido',
|
||||
'guido@python.org')])
|
||||
|
||||
self.check(
|
||||
'To: "Amit J. Patel" <amitp@Theory.Stanford.EDU>\n'
|
||||
'CC: Mike Fletcher <mfletch@vrtelecom.com>,\n'
|
||||
' "\'string-sig@python.org\'" <string-sig@python.org>\n'
|
||||
'Cc: fooz@bat.com, bart@toof.com\n'
|
||||
'Cc: goit@lip.com\n'
|
||||
'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('Amit J. Patel', 'amitp@Theory.Stanford.EDU'),
|
||||
('Mike Fletcher', 'mfletch@vrtelecom.com'),
|
||||
("'string-sig@python.org'", 'string-sig@python.org'),
|
||||
('', 'fooz@bat.com'),
|
||||
('', 'bart@toof.com'),
|
||||
('', 'goit@lip.com'),
|
||||
])
|
||||
|
||||
self.check(
|
||||
'To: Some One <someone@dom.ain>\n'
|
||||
'From: Anudder Persin <subuddy.else@dom.ain>\n'
|
||||
'Date:\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('Some One', 'someone@dom.ain')])
|
||||
|
||||
self.check(
|
||||
'To: person@dom.ain (User J. Person)\n\n',
|
||||
[('User J. Person', 'person@dom.ain')])
|
||||
|
||||
def test_doublecomment(self):
|
||||
# The RFC allows comments within comments in an email addr
|
||||
self.check(
|
||||
'To: person@dom.ain ((User J. Person)), John Doe <foo@bar.com>\n\n',
|
||||
[('User J. Person', 'person@dom.ain'), ('John Doe', 'foo@bar.com')])
|
||||
|
||||
def test_twisted(self):
|
||||
# This one is just twisted. I don't know what the proper
|
||||
# result should be, but it shouldn't be to infloop, which is
|
||||
# what used to happen!
|
||||
self.check(
|
||||
'To: <[smtp:dd47@mail.xxx.edu]_at_hmhq@hdq-mdm1-imgout.companay.com>\n'
|
||||
'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('', ''),
|
||||
('', 'dd47@mail.xxx.edu'),
|
||||
('', '_at_hmhq@hdq-mdm1-imgout.companay.com'),
|
||||
])
|
||||
|
||||
def test_commas_in_full_name(self):
|
||||
# This exercises the old commas-in-a-full-name bug, which
|
||||
# should be doing the right thing in recent versions of the
|
||||
# module.
|
||||
self.check(
|
||||
'To: "last, first" <userid@foo.net>\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('last, first', 'userid@foo.net')])
|
||||
|
||||
def test_quoted_name(self):
|
||||
self.check(
|
||||
'To: (Comment stuff) "Quoted name"@somewhere.com\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('Comment stuff', '"Quoted name"@somewhere.com')])
|
||||
|
||||
def test_bogus_to_header(self):
|
||||
self.check(
|
||||
'To: :\n'
|
||||
'Cc: goit@lip.com\n'
|
||||
'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'
|
||||
'\n'
|
||||
'test',
|
||||
[('', 'goit@lip.com')])
|
||||
|
||||
def test_addr_ipquad(self):
|
||||
self.check(
|
||||
'To: guido@[132.151.1.21]\n'
|
||||
'\n'
|
||||
'foo',
|
||||
[('', 'guido@[132.151.1.21]')])
|
||||
|
||||
def test_iter(self):
|
||||
m = rfc822.Message(StringIO(
|
||||
'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'
|
||||
'From: Guido van Rossum <guido@CNRI.Reston.VA.US>\n'
|
||||
'To: "Guido van\n'
|
||||
'\t : Rossum" <guido@python.org>\n'
|
||||
'Subject: test2\n'
|
||||
'\n'
|
||||
'test2\n' ))
|
||||
self.assertEqual(sorted(m), ['date', 'from', 'subject', 'to'])
|
||||
|
||||
def test_rfc2822_phrases(self):
|
||||
# RFC 2822 (the update to RFC 822) specifies that dots in phrases are
|
||||
# obsolete syntax, which conforming programs MUST recognize but NEVER
|
||||
# generate (see $4.1 Miscellaneous obsolete tokens). This is a
|
||||
# departure from RFC 822 which did not allow dots in non-quoted
|
||||
# phrases.
|
||||
self.check('To: User J. Person <person@dom.ain>\n\n',
|
||||
[('User J. Person', 'person@dom.ain')])
|
||||
|
||||
# This takes too long to add to the test suite
|
||||
## def test_an_excrutiatingly_long_address_field(self):
|
||||
## OBSCENELY_LONG_HEADER_MULTIPLIER = 10000
|
||||
## oneaddr = ('Person' * 10) + '@' + ('.'.join(['dom']*10)) + '.com'
|
||||
## addr = ', '.join([oneaddr] * OBSCENELY_LONG_HEADER_MULTIPLIER)
|
||||
## lst = rfc822.AddrlistClass(addr).getaddrlist()
|
||||
## self.assertEqual(len(lst), OBSCENELY_LONG_HEADER_MULTIPLIER)
|
||||
|
||||
def test_2getaddrlist(self):
|
||||
eq = self.assertEqual
|
||||
msg = self.create_message("""\
|
||||
To: aperson@dom.ain
|
||||
Cc: bperson@dom.ain
|
||||
Cc: cperson@dom.ain
|
||||
Cc: dperson@dom.ain
|
||||
|
||||
A test message.
|
||||
""")
|
||||
ccs = [('', a) for a in
|
||||
['bperson@dom.ain', 'cperson@dom.ain', 'dperson@dom.ain']]
|
||||
addrs = msg.getaddrlist('cc')
|
||||
addrs.sort()
|
||||
eq(addrs, ccs)
|
||||
# Try again, this one used to fail
|
||||
addrs = msg.getaddrlist('cc')
|
||||
addrs.sort()
|
||||
eq(addrs, ccs)
|
||||
|
||||
def test_parseaddr(self):
|
||||
eq = self.assertEqual
|
||||
eq(rfc822.parseaddr('<>'), ('', ''))
|
||||
eq(rfc822.parseaddr('aperson@dom.ain'), ('', 'aperson@dom.ain'))
|
||||
eq(rfc822.parseaddr('bperson@dom.ain (Bea A. Person)'),
|
||||
('Bea A. Person', 'bperson@dom.ain'))
|
||||
eq(rfc822.parseaddr('Cynthia Person <cperson@dom.ain>'),
|
||||
('Cynthia Person', 'cperson@dom.ain'))
|
||||
|
||||
def test_quote_unquote(self):
|
||||
eq = self.assertEqual
|
||||
eq(rfc822.quote('foo\\wacky"name'), 'foo\\\\wacky\\"name')
|
||||
eq(rfc822.unquote('"foo\\\\wacky\\"name"'), 'foo\\wacky"name')
|
||||
|
||||
|
||||
def test_main():
|
||||
test_support.run_unittest(MessageTestCase)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
test_main()
|
Reference in New Issue
Block a user