test_quopri.py

来自「mallet是自然语言处理、机器学习领域的一个开源项目。」· Python 代码 · 共 158 行

PY
158
字号
import test_supportimport unittestfrom cStringIO import StringIOfrom quopri import *ENCSAMPLE = """\Here's a bunch of special=20=A1=A2=A3=A4=A5=A6=A7=A8=A9=AA=AB=AC=AD=AE=AF=B0=B1=B2=B3=B4=B5=B6=B7=B8=B9=BA=BB=BC=BD=BE=BF=C0=C1=C2=C3=C4=C5=C6=C7=C8=C9=CA=CB=CC=CD=CE=CF=D0=D1=D2=D3=D4=D5=D6=D7=D8=D9=DA=DB=DC=DD=DE=DF=E0=E1=E2=E3=E4=E5=E6=E7=E8=E9=EA=EB=EC=ED=EE=EF=F0=F1=F2=F3=F4=F5=F6=F7=F8=F9=FA=FB=FC=FD=FE=FFcharacters... have fun!"""# First line ends with a spaceDECSAMPLE = "Here's a bunch of special \n" + \"""\\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xffcharacters... have fun!"""class QuopriTestCase(unittest.TestCase):    # Each entry is a tuple of (plaintext, encoded string).  These strings are    # used in the "quotetabs=0" tests.    STRINGS = (        # Some normal strings        ('hello', 'hello'),        ('''hello        there        world''', '''hello        there        world'''),        ('''hello        there        world''', '''hello        there        world'''),        ('\201\202\203', '=81=82=83'),        # Add some trailing MUST QUOTE strings        ('hello ', 'hello=20'),        ('hello\t', 'hello=09'),        # Some long lines.  First, a single line of 108 characters        ('xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\xd8\xd9\xda\xdb\xdc\xdd\xde\xdfxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',         '''xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx=D8=D9=DA=DB=DC=DD=DE=DFx=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'''),        # A line of exactly 76 characters, no soft line break should be needed        ('yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy',        'yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy'),        # A line of 77 characters, forcing a soft line break at position 75,        # and a second line of exactly 2 characters (because the soft line        # break `=' sign counts against the line length limit).        ('zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz',         '''zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz=zz'''),        # A line of 151 characters, forcing a soft line break at position 75,        # with a second line of exactly 76 characters and no trailing =        ('zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz',         '''zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz=zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz'''),        # A string containing a hard line break, but which the first line is        # 151 characters and the second line is exactly 76 characters.  This        # should leave us with three lines, the first which has a soft line        # break, and which the second and third do not.        ('''yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz''',         '''yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy=yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz'''),        # Now some really complex stuff ;)        (DECSAMPLE, ENCSAMPLE),        )    # These are used in the "quotetabs=1" tests.    ESTRINGS = (        ('hello world', 'hello=20world'),        ('hello\tworld', 'hello=09world'),        )    # These are used in the "header=1" tests.    HSTRINGS = (        ('hello world', 'hello_world'),        ('hello_world', 'hello=5Fworld'),        )    def test_encodestring(self):        for p, e in self.STRINGS:            self.assert_(encodestring(p) == e)    def test_decodestring(self):        for p, e in self.STRINGS:            self.assert_(decodestring(e) == p)    def test_idempotent_string(self):        for p, e in self.STRINGS:            self.assert_(decodestring(encodestring(e)) == e)    def test_encode(self):        for p, e in self.STRINGS:            infp = StringIO(p)            outfp = StringIO()            encode(infp, outfp, quotetabs=0)            self.assert_(outfp.getvalue() == e)    def test_decode(self):        for p, e in self.STRINGS:            infp = StringIO(e)            outfp = StringIO()            decode(infp, outfp)            self.assert_(outfp.getvalue() == p)    def test_embedded_ws(self):        for p, e in self.ESTRINGS:            self.assert_(encodestring(p, quotetabs=1) == e)            self.assert_(decodestring(e) == p)    def test_encode_header(self):        for p, e in self.HSTRINGS:            self.assert_(encodestring(p, header = 1) == e)    def test_decode_header(self):        for p, e in self.HSTRINGS:            self.assert_(decodestring(e, header = 1) == p)def test_main():    test_support.run_unittest(QuopriTestCase)if __name__ == "__main__":    test_main()

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?