mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 10:26:02 +00:00 
			
		
		
		
	 80e0aee95b
			
		
	
	
		80e0aee95b
		
	
	
	
	
		
			
			Which also means that it is now producing *something* for any base64 payload, which is what leads to the couple of older test changes in test_email. This is a slightly backward incompatible behavior change, but the new behavior is so much more useful than the old (you can now *reliably* detect errors, and any program that was detecting errors by sniffing for a base64 return from get_payload(decode=True) and then doing its own error-recovery decode will just get the error-recovery decode right away). So this seems to me to be worth the small risk inherent in this behavior change. This patch also refactors the defect tests into a separate test file, since they are no longer just parser tests.
		
			
				
	
	
		
			36 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import io
 | |
| import email
 | |
| import unittest
 | |
| from email.message import Message
 | |
| from test.test_email import TestEmailBase
 | |
| 
 | |
| 
 | |
| class TestCustomMessage(TestEmailBase):
 | |
| 
 | |
|     class MyMessage(Message):
 | |
|         def __init__(self, policy):
 | |
|             self.check_policy = policy
 | |
|             super().__init__()
 | |
| 
 | |
|     MyPolicy = TestEmailBase.policy.clone(linesep='boo')
 | |
| 
 | |
|     def test_custom_message_gets_policy_if_possible_from_string(self):
 | |
|         msg = email.message_from_string("Subject: bogus\n\nmsg\n",
 | |
|                                         self.MyMessage,
 | |
|                                         policy=self.MyPolicy)
 | |
|         self.assertTrue(isinstance(msg, self.MyMessage))
 | |
|         self.assertIs(msg.check_policy, self.MyPolicy)
 | |
| 
 | |
|     def test_custom_message_gets_policy_if_possible_from_file(self):
 | |
|         source_file = io.StringIO("Subject: bogus\n\nmsg\n")
 | |
|         msg = email.message_from_file(source_file,
 | |
|                                       self.MyMessage,
 | |
|                                       policy=self.MyPolicy)
 | |
|         self.assertTrue(isinstance(msg, self.MyMessage))
 | |
|         self.assertIs(msg.check_policy, self.MyPolicy)
 | |
| 
 | |
|     # XXX add tests for other functions that take Message arg.
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     unittest.main()
 |