| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  | """Test the binascii C module.""" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-07-30 23:27:12 +00:00
										 |  |  | from test.test_support import verify, verbose, have_unicode | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  | import binascii | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Show module doc string | 
					
						
							|  |  |  | print binascii.__doc__ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Show module exceptions | 
					
						
							|  |  |  | print binascii.Error | 
					
						
							|  |  |  | print binascii.Incomplete | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Check presence and display doc strings of all functions | 
					
						
							|  |  |  | funcs = [] | 
					
						
							|  |  |  | for suffix in "base64", "hqx", "uu": | 
					
						
							|  |  |  |     prefixes = ["a2b_", "b2a_"] | 
					
						
							|  |  |  |     if suffix == "hqx": | 
					
						
							|  |  |  |         prefixes.extend(["crc_", "rlecode_", "rledecode_"]) | 
					
						
							|  |  |  |     for prefix in prefixes: | 
					
						
							|  |  |  |         name = prefix + suffix | 
					
						
							|  |  |  |         funcs.append(getattr(binascii, name)) | 
					
						
							|  |  |  | for func in funcs: | 
					
						
							|  |  |  |     print "%-15s: %s" % (func.__name__, func.__doc__) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Create binary test data | 
					
						
							|  |  |  | testdata = "The quick brown fox jumps over the lazy dog.\r\n" | 
					
						
							|  |  |  | for i in range(256): | 
					
						
							|  |  |  |     # Be slow so we don't depend on other modules | 
					
						
							|  |  |  |     testdata = testdata + chr(i) | 
					
						
							|  |  |  | testdata = testdata + "\r\nHello world.\n" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Test base64 with valid data | 
					
						
							|  |  |  | print "base64 test" | 
					
						
							|  |  |  | MAX_BASE64 = 57 | 
					
						
							|  |  |  | lines = [] | 
					
						
							|  |  |  | for i in range(0, len(testdata), MAX_BASE64): | 
					
						
							|  |  |  |     b = testdata[i:i+MAX_BASE64] | 
					
						
							|  |  |  |     a = binascii.b2a_base64(b) | 
					
						
							|  |  |  |     lines.append(a) | 
					
						
							|  |  |  |     print a, | 
					
						
							|  |  |  | res = "" | 
					
						
							|  |  |  | for line in lines: | 
					
						
							|  |  |  |     b = binascii.a2b_base64(line) | 
					
						
							|  |  |  |     res = res + b | 
					
						
							| 
									
										
										
										
											2001-01-17 19:11:13 +00:00
										 |  |  | verify(res == testdata) | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Test base64 with random invalid characters sprinkled throughout | 
					
						
							|  |  |  | # (This requires a new version of binascii.) | 
					
						
							|  |  |  | fillers = "" | 
					
						
							|  |  |  | valid = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/" | 
					
						
							|  |  |  | for i in range(256): | 
					
						
							|  |  |  |     c = chr(i) | 
					
						
							|  |  |  |     if c not in valid: | 
					
						
							|  |  |  |         fillers = fillers + c | 
					
						
							|  |  |  | def addnoise(line): | 
					
						
							|  |  |  |     noise = fillers | 
					
						
							| 
									
										
										
										
											2001-09-04 19:14:14 +00:00
										 |  |  |     ratio = len(line) // len(noise) | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  |     res = "" | 
					
						
							|  |  |  |     while line and noise: | 
					
						
							| 
									
										
										
										
											2001-09-04 19:14:14 +00:00
										 |  |  |         if len(line) // len(noise) > ratio: | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  |             c, line = line[0], line[1:] | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             c, noise = noise[0], noise[1:] | 
					
						
							|  |  |  |         res = res + c | 
					
						
							|  |  |  |     return res + noise + line | 
					
						
							|  |  |  | res = "" | 
					
						
							|  |  |  | for line in map(addnoise, lines): | 
					
						
							|  |  |  |     b = binascii.a2b_base64(line) | 
					
						
							|  |  |  |     res = res + b | 
					
						
							| 
									
										
										
										
											2001-01-17 19:11:13 +00:00
										 |  |  | verify(res == testdata) | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-03-17 11:24:29 +00:00
										 |  |  | # Test base64 with just invalid characters, which should return | 
					
						
							|  |  |  | # empty strings. TBD: shouldn't it raise an exception instead ? | 
					
						
							|  |  |  | verify(binascii.a2b_base64(fillers) == '') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  | # Test uu | 
					
						
							|  |  |  | print "uu test" | 
					
						
							|  |  |  | MAX_UU = 45 | 
					
						
							|  |  |  | lines = [] | 
					
						
							|  |  |  | for i in range(0, len(testdata), MAX_UU): | 
					
						
							|  |  |  |     b = testdata[i:i+MAX_UU] | 
					
						
							|  |  |  |     a = binascii.b2a_uu(b) | 
					
						
							|  |  |  |     lines.append(a) | 
					
						
							|  |  |  |     print a, | 
					
						
							|  |  |  | res = "" | 
					
						
							|  |  |  | for line in lines: | 
					
						
							|  |  |  |     b = binascii.a2b_uu(line) | 
					
						
							|  |  |  |     res = res + b | 
					
						
							| 
									
										
										
										
											2001-01-17 19:11:13 +00:00
										 |  |  | verify(res == testdata) | 
					
						
							| 
									
										
										
										
											1997-01-16 16:44:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-02-16 21:13:06 +00:00
										 |  |  | # Test crc32() | 
					
						
							|  |  |  | crc = binascii.crc32("Test the CRC-32 of") | 
					
						
							|  |  |  | crc = binascii.crc32(" this string.", crc) | 
					
						
							|  |  |  | if crc != 1571220330: | 
					
						
							|  |  |  |     print "binascii.crc32() failed." | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-10-19 19:08:13 +00:00
										 |  |  | # The hqx test is in test_binhex.py | 
					
						
							| 
									
										
										
										
											2000-08-15 06:08:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # test hexlification | 
					
						
							|  |  |  | s = '{s\005\000\000\000worldi\002\000\000\000s\005\000\000\000helloi\001\000\000\0000' | 
					
						
							|  |  |  | t = binascii.b2a_hex(s) | 
					
						
							|  |  |  | u = binascii.a2b_hex(t) | 
					
						
							| 
									
										
										
										
											2000-12-12 23:11:42 +00:00
										 |  |  | if s != u: | 
					
						
							| 
									
										
										
										
											2000-08-15 06:08:31 +00:00
										 |  |  |     print 'binascii hexlification failed' | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     binascii.a2b_hex(t[:-1]) | 
					
						
							|  |  |  | except TypeError: | 
					
						
							|  |  |  |     pass | 
					
						
							|  |  |  | else: | 
					
						
							|  |  |  |     print 'expected TypeError not raised' | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     binascii.a2b_hex(t[:-1] + 'q') | 
					
						
							|  |  |  | except TypeError: | 
					
						
							|  |  |  |     pass | 
					
						
							|  |  |  | else: | 
					
						
							|  |  |  |     print 'expected TypeError not raised' | 
					
						
							| 
									
										
										
										
											2001-10-11 14:09:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Verify the treatment of Unicode strings | 
					
						
							| 
									
										
										
										
											2002-05-20 14:15:42 +00:00
										 |  |  | if have_unicode: | 
					
						
							| 
									
										
										
										
											2002-05-23 15:15:30 +00:00
										 |  |  |     verify(binascii.hexlify(unicode('a', 'ascii')) == '61', | 
					
						
							| 
									
										
										
										
											2002-05-20 14:15:42 +00:00
										 |  |  |            "hexlify failed for Unicode") | 
					
						
							| 
									
										
										
										
											2002-04-04 16:27:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # A test for SF bug 534347 (segfaults without the proper fix) | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     binascii.a2b_qp("", **{1:1}) | 
					
						
							|  |  |  | except TypeError: | 
					
						
							|  |  |  |     pass | 
					
						
							|  |  |  | else: | 
					
						
							|  |  |  |     raise TestFailed, "binascii..a2b_qp(**{1:1}) didn't raise TypeError" |