]>
Commit | Line | Data |
---|---|---|
4710c53d | 1 | import unittest\r |
2 | from test import test_support\r | |
3 | \r | |
4 | rfc822 = test_support.import_module("rfc822", deprecated=True)\r | |
5 | \r | |
6 | try:\r | |
7 | from cStringIO import StringIO\r | |
8 | except ImportError:\r | |
9 | from StringIO import StringIO\r | |
10 | \r | |
11 | \r | |
12 | class MessageTestCase(unittest.TestCase):\r | |
13 | def create_message(self, msg):\r | |
14 | return rfc822.Message(StringIO(msg))\r | |
15 | \r | |
16 | def test_get(self):\r | |
17 | msg = self.create_message(\r | |
18 | 'To: "last, first" <userid@foo.net>\n\ntest\n')\r | |
19 | self.assertTrue(msg.get("to") == '"last, first" <userid@foo.net>')\r | |
20 | self.assertTrue(msg.get("TO") == '"last, first" <userid@foo.net>')\r | |
21 | self.assertTrue(msg.get("No-Such-Header") is None)\r | |
22 | self.assertTrue(msg.get("No-Such-Header", "No-Such-Value")\r | |
23 | == "No-Such-Value")\r | |
24 | \r | |
25 | def test_setdefault(self):\r | |
26 | msg = self.create_message(\r | |
27 | 'To: "last, first" <userid@foo.net>\n\ntest\n')\r | |
28 | self.assertTrue(not msg.has_key("New-Header"))\r | |
29 | self.assertTrue(msg.setdefault("New-Header", "New-Value") == "New-Value")\r | |
30 | self.assertTrue(msg.setdefault("New-Header", "Different-Value")\r | |
31 | == "New-Value")\r | |
32 | self.assertTrue(msg["new-header"] == "New-Value")\r | |
33 | \r | |
34 | self.assertTrue(msg.setdefault("Another-Header") == "")\r | |
35 | self.assertTrue(msg["another-header"] == "")\r | |
36 | \r | |
37 | def check(self, msg, results):\r | |
38 | """Check addresses and the date."""\r | |
39 | m = self.create_message(msg)\r | |
40 | i = 0\r | |
41 | for n, a in m.getaddrlist('to') + m.getaddrlist('cc'):\r | |
42 | try:\r | |
43 | mn, ma = results[i][0], results[i][1]\r | |
44 | except IndexError:\r | |
45 | print 'extra parsed address:', repr(n), repr(a)\r | |
46 | continue\r | |
47 | i = i + 1\r | |
48 | self.assertEqual(mn, n,\r | |
49 | "Un-expected name: %r != %r" % (mn, n))\r | |
50 | self.assertEqual(ma, a,\r | |
51 | "Un-expected address: %r != %r" % (ma, a))\r | |
52 | if mn == n and ma == a:\r | |
53 | pass\r | |
54 | else:\r | |
55 | print 'not found:', repr(n), repr(a)\r | |
56 | \r | |
57 | out = m.getdate('date')\r | |
58 | if out:\r | |
59 | self.assertEqual(out,\r | |
60 | (1999, 1, 13, 23, 57, 35, 0, 1, 0),\r | |
61 | "date conversion failed")\r | |
62 | \r | |
63 | \r | |
64 | # Note: all test cases must have the same date (in various formats),\r | |
65 | # or no date!\r | |
66 | \r | |
67 | def test_basic(self):\r | |
68 | self.check(\r | |
69 | 'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'\r | |
70 | 'From: Guido van Rossum <guido@CNRI.Reston.VA.US>\n'\r | |
71 | 'To: "Guido van\n'\r | |
72 | '\t : Rossum" <guido@python.org>\n'\r | |
73 | 'Subject: test2\n'\r | |
74 | '\n'\r | |
75 | 'test2\n',\r | |
76 | [('Guido van\n\t : Rossum', 'guido@python.org')])\r | |
77 | \r | |
78 | self.check(\r | |
79 | 'From: Barry <bwarsaw@python.org\n'\r | |
80 | 'To: guido@python.org (Guido: the Barbarian)\n'\r | |
81 | 'Subject: nonsense\n'\r | |
82 | 'Date: Wednesday, January 13 1999 23:57:35 -0500\n'\r | |
83 | '\n'\r | |
84 | 'test',\r | |
85 | [('Guido: the Barbarian', 'guido@python.org')])\r | |
86 | \r | |
87 | self.check(\r | |
88 | 'From: Barry <bwarsaw@python.org\n'\r | |
89 | 'To: guido@python.org (Guido: the Barbarian)\n'\r | |
90 | 'Cc: "Guido: the Madman" <guido@python.org>\n'\r | |
91 | 'Date: 13-Jan-1999 23:57:35 EST\n'\r | |
92 | '\n'\r | |
93 | 'test',\r | |
94 | [('Guido: the Barbarian', 'guido@python.org'),\r | |
95 | ('Guido: the Madman', 'guido@python.org')\r | |
96 | ])\r | |
97 | \r | |
98 | self.check(\r | |
99 | 'To: "The monster with\n'\r | |
100 | ' the very long name: Guido" <guido@python.org>\n'\r | |
101 | 'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'\r | |
102 | '\n'\r | |
103 | 'test',\r | |
104 | [('The monster with\n the very long name: Guido',\r | |
105 | 'guido@python.org')])\r | |
106 | \r | |
107 | self.check(\r | |
108 | 'To: "Amit J. Patel" <amitp@Theory.Stanford.EDU>\n'\r | |
109 | 'CC: Mike Fletcher <mfletch@vrtelecom.com>,\n'\r | |
110 | ' "\'string-sig@python.org\'" <string-sig@python.org>\n'\r | |
111 | 'Cc: fooz@bat.com, bart@toof.com\n'\r | |
112 | 'Cc: goit@lip.com\n'\r | |
113 | 'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'\r | |
114 | '\n'\r | |
115 | 'test',\r | |
116 | [('Amit J. Patel', 'amitp@Theory.Stanford.EDU'),\r | |
117 | ('Mike Fletcher', 'mfletch@vrtelecom.com'),\r | |
118 | ("'string-sig@python.org'", 'string-sig@python.org'),\r | |
119 | ('', 'fooz@bat.com'),\r | |
120 | ('', 'bart@toof.com'),\r | |
121 | ('', 'goit@lip.com'),\r | |
122 | ])\r | |
123 | \r | |
124 | self.check(\r | |
125 | 'To: Some One <someone@dom.ain>\n'\r | |
126 | 'From: Anudder Persin <subuddy.else@dom.ain>\n'\r | |
127 | 'Date:\n'\r | |
128 | '\n'\r | |
129 | 'test',\r | |
130 | [('Some One', 'someone@dom.ain')])\r | |
131 | \r | |
132 | self.check(\r | |
133 | 'To: person@dom.ain (User J. Person)\n\n',\r | |
134 | [('User J. Person', 'person@dom.ain')])\r | |
135 | \r | |
136 | def test_doublecomment(self):\r | |
137 | # The RFC allows comments within comments in an email addr\r | |
138 | self.check(\r | |
139 | 'To: person@dom.ain ((User J. Person)), John Doe <foo@bar.com>\n\n',\r | |
140 | [('User J. Person', 'person@dom.ain'), ('John Doe', 'foo@bar.com')])\r | |
141 | \r | |
142 | def test_twisted(self):\r | |
143 | # This one is just twisted. I don't know what the proper\r | |
144 | # result should be, but it shouldn't be to infloop, which is\r | |
145 | # what used to happen!\r | |
146 | self.check(\r | |
147 | 'To: <[smtp:dd47@mail.xxx.edu]_at_hmhq@hdq-mdm1-imgout.companay.com>\n'\r | |
148 | 'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'\r | |
149 | '\n'\r | |
150 | 'test',\r | |
151 | [('', ''),\r | |
152 | ('', 'dd47@mail.xxx.edu'),\r | |
153 | ('', '_at_hmhq@hdq-mdm1-imgout.companay.com'),\r | |
154 | ])\r | |
155 | \r | |
156 | def test_commas_in_full_name(self):\r | |
157 | # This exercises the old commas-in-a-full-name bug, which\r | |
158 | # should be doing the right thing in recent versions of the\r | |
159 | # module.\r | |
160 | self.check(\r | |
161 | 'To: "last, first" <userid@foo.net>\n'\r | |
162 | '\n'\r | |
163 | 'test',\r | |
164 | [('last, first', 'userid@foo.net')])\r | |
165 | \r | |
166 | def test_quoted_name(self):\r | |
167 | self.check(\r | |
168 | 'To: (Comment stuff) "Quoted name"@somewhere.com\n'\r | |
169 | '\n'\r | |
170 | 'test',\r | |
171 | [('Comment stuff', '"Quoted name"@somewhere.com')])\r | |
172 | \r | |
173 | def test_bogus_to_header(self):\r | |
174 | self.check(\r | |
175 | 'To: :\n'\r | |
176 | 'Cc: goit@lip.com\n'\r | |
177 | 'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'\r | |
178 | '\n'\r | |
179 | 'test',\r | |
180 | [('', 'goit@lip.com')])\r | |
181 | \r | |
182 | def test_addr_ipquad(self):\r | |
183 | self.check(\r | |
184 | 'To: guido@[132.151.1.21]\n'\r | |
185 | '\n'\r | |
186 | 'foo',\r | |
187 | [('', 'guido@[132.151.1.21]')])\r | |
188 | \r | |
189 | def test_iter(self):\r | |
190 | m = rfc822.Message(StringIO(\r | |
191 | 'Date: Wed, 13 Jan 1999 23:57:35 -0500\n'\r | |
192 | 'From: Guido van Rossum <guido@CNRI.Reston.VA.US>\n'\r | |
193 | 'To: "Guido van\n'\r | |
194 | '\t : Rossum" <guido@python.org>\n'\r | |
195 | 'Subject: test2\n'\r | |
196 | '\n'\r | |
197 | 'test2\n' ))\r | |
198 | self.assertEqual(sorted(m), ['date', 'from', 'subject', 'to'])\r | |
199 | \r | |
200 | def test_rfc2822_phrases(self):\r | |
201 | # RFC 2822 (the update to RFC 822) specifies that dots in phrases are\r | |
202 | # obsolete syntax, which conforming programs MUST recognize but NEVER\r | |
203 | # generate (see $4.1 Miscellaneous obsolete tokens). This is a\r | |
204 | # departure from RFC 822 which did not allow dots in non-quoted\r | |
205 | # phrases.\r | |
206 | self.check('To: User J. Person <person@dom.ain>\n\n',\r | |
207 | [('User J. Person', 'person@dom.ain')])\r | |
208 | \r | |
209 | # This takes too long to add to the test suite\r | |
210 | ## def test_an_excrutiatingly_long_address_field(self):\r | |
211 | ## OBSCENELY_LONG_HEADER_MULTIPLIER = 10000\r | |
212 | ## oneaddr = ('Person' * 10) + '@' + ('.'.join(['dom']*10)) + '.com'\r | |
213 | ## addr = ', '.join([oneaddr] * OBSCENELY_LONG_HEADER_MULTIPLIER)\r | |
214 | ## lst = rfc822.AddrlistClass(addr).getaddrlist()\r | |
215 | ## self.assertEqual(len(lst), OBSCENELY_LONG_HEADER_MULTIPLIER)\r | |
216 | \r | |
217 | def test_2getaddrlist(self):\r | |
218 | eq = self.assertEqual\r | |
219 | msg = self.create_message("""\\r | |
220 | To: aperson@dom.ain\r | |
221 | Cc: bperson@dom.ain\r | |
222 | Cc: cperson@dom.ain\r | |
223 | Cc: dperson@dom.ain\r | |
224 | \r | |
225 | A test message.\r | |
226 | """)\r | |
227 | ccs = [('', a) for a in\r | |
228 | ['bperson@dom.ain', 'cperson@dom.ain', 'dperson@dom.ain']]\r | |
229 | addrs = msg.getaddrlist('cc')\r | |
230 | addrs.sort()\r | |
231 | eq(addrs, ccs)\r | |
232 | # Try again, this one used to fail\r | |
233 | addrs = msg.getaddrlist('cc')\r | |
234 | addrs.sort()\r | |
235 | eq(addrs, ccs)\r | |
236 | \r | |
237 | def test_parseaddr(self):\r | |
238 | eq = self.assertEqual\r | |
239 | eq(rfc822.parseaddr('<>'), ('', ''))\r | |
240 | eq(rfc822.parseaddr('aperson@dom.ain'), ('', 'aperson@dom.ain'))\r | |
241 | eq(rfc822.parseaddr('bperson@dom.ain (Bea A. Person)'),\r | |
242 | ('Bea A. Person', 'bperson@dom.ain'))\r | |
243 | eq(rfc822.parseaddr('Cynthia Person <cperson@dom.ain>'),\r | |
244 | ('Cynthia Person', 'cperson@dom.ain'))\r | |
245 | \r | |
246 | def test_quote_unquote(self):\r | |
247 | eq = self.assertEqual\r | |
248 | eq(rfc822.quote('foo\\wacky"name'), 'foo\\\\wacky\\"name')\r | |
249 | eq(rfc822.unquote('"foo\\\\wacky\\"name"'), 'foo\\wacky"name')\r | |
250 | \r | |
251 | \r | |
252 | def test_main():\r | |
253 | test_support.run_unittest(MessageTestCase)\r | |
254 | \r | |
255 | \r | |
256 | if __name__ == "__main__":\r | |
257 | test_main()\r |