test_zlib.py 5.9 KB
Newer Older
Jeremy Hylton's avatar
Jeremy Hylton committed
1
import zlib
2
from test_support import TestFailed
Jeremy Hylton's avatar
Jeremy Hylton committed
3
import sys
4
import imp
Jeremy Hylton's avatar
Jeremy Hylton committed
5

6 7 8 9 10
try:
    t = imp.find_module('test_zlib')
    file = t[0]
except ImportError:
    file = open(__file__)
11 12
buf = file.read() * 8
file.close()
Jeremy Hylton's avatar
Jeremy Hylton committed
13

Jeremy Hylton's avatar
Jeremy Hylton committed
14
# test the checksums (hex so the test doesn't break on 64-bit machines)
15 16
print hex(zlib.crc32('penguin')), hex(zlib.crc32('penguin', 1))
print hex(zlib.adler32('penguin')), hex(zlib.adler32('penguin', 1))
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

# make sure we generate some expected errors
try:
    zlib.compress('ERROR', zlib.MAX_WBITS + 1)
except zlib.error, msg:
    print "expecting", msg
try:
    zlib.compressobj(1, 8, 0)
except ValueError, msg:
    print "expecting", msg
try:
    zlib.decompressobj(0)
except ValueError, msg:
    print "expecting", msg

Jeremy Hylton's avatar
Jeremy Hylton committed
32 33 34 35
x = zlib.compress(buf)
y = zlib.decompress(x)
if buf != y:
    print "normal compression/decompression failed"
36 37
else:
    print "normal compression/decompression succeeded"
Jeremy Hylton's avatar
Jeremy Hylton committed
38 39 40 41 42 43 44 45 46 47 48 49 50 51

buf = buf * 16

co = zlib.compressobj(8, 8, -15)
x1 = co.compress(buf)
x2 = co.flush()
x = x1 + x2

dc = zlib.decompressobj(-15)
y1 = dc.decompress(x)
y2 = dc.flush()
y = y1 + y2
if buf != y:
    print "compress/decompression obj failed"
52 53 54 55 56 57 58 59
else:
    print "compress/decompression obj succeeded"

co = zlib.compressobj(2, 8, -12, 9, 1)
bufs = []
for i in range(0, len(buf), 256):
    bufs.append(co.compress(buf[i:i+256]))
bufs.append(co.flush())
60
combuf = ''.join(bufs)
61 62 63 64 65 66 67 68 69 70 71 72

decomp1 = zlib.decompress(combuf, -12, -5)
if decomp1 != buf:
    print "decompress with init options failed"
else:
    print "decompress with init options succeeded"

deco = zlib.decompressobj(-12)
bufs = []
for i in range(0, len(combuf), 128):
    bufs.append(deco.decompress(combuf[i:i+128]))
bufs.append(deco.flush())
73
decomp2 = ''.join(bufs)
74 75 76 77
if decomp2 != buf:
    print "decompressobj with init options failed"
else:
    print "decompressobj with init options succeeded"
Jeremy Hylton's avatar
Jeremy Hylton committed
78

79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
print "should be '':", `deco.unconsumed_tail`

# Check a decompression object with max_length specified
deco = zlib.decompressobj(-12)
cb = combuf
bufs = []
while cb:
    max_length = 1 + len(cb)/10
    chunk = deco.decompress(cb, max_length)
    if len(chunk) > max_length:
        print 'chunk too big (%d>%d)' % (len(chunk),max_length)
    bufs.append(chunk)
    cb = deco.unconsumed_tail
bufs.append(deco.flush())
decomp2 = ''.join(buf)
if decomp2 != buf:
    print "max_length decompressobj failed"
else:
    print "max_length decompressobj succeeded"
Tim Peters's avatar
Tim Peters committed
98

99 100 101 102 103 104 105 106 107 108
# Misc tests of max_length
deco = zlib.decompressobj(-12)
try:
    deco.decompress("", -1)
except ValueError:
    pass
else:
    print "failed to raise value error on bad max_length"
print "unconsumed_tail should be '':", `deco.unconsumed_tail`

109 110
# Test flush() with the various options, using all the different levels
# in order to provide more variations.
111 112 113 114
sync_opt = ['Z_NO_FLUSH', 'Z_SYNC_FLUSH', 'Z_FULL_FLUSH']
sync_opt = [getattr(zlib, opt) for opt in sync_opt if hasattr(zlib, opt)]

for sync in sync_opt:
115
    for level in range(10):
116 117 118 119 120 121 122 123
        obj = zlib.compressobj( level )
        d = obj.compress( buf[:3000] )
        d = d + obj.flush( sync )
        d = d + obj.compress( buf[3000:] )
        d = d + obj.flush()
        if zlib.decompress(d) != buf:
            print "Decompress failed: flush mode=%i, level=%i" % (sync,level)
        del obj
124

125 126 127
# Test for the odd flushing bugs noted in 2.0, and hopefully fixed in 2.1

import random
Tim Peters's avatar
Tim Peters committed
128
random.seed(1)
129 130 131

print 'Testing on 17K of random data'

132 133 134 135 136
if hasattr(zlib, 'Z_SYNC_FLUSH'):

    # Create compressor and decompressor objects
    c=zlib.compressobj(9)
    d=zlib.decompressobj()
137

138 139 140 141 142
    # Try 17K of data
    # generate random data stream
    a=""
    for i in range(17*1024):
        a=a+chr(random.randint(0,255))
Tim Peters's avatar
Tim Peters committed
143

144 145
    # compress, sync-flush, and decompress
    t = d.decompress( c.compress(a)+c.flush(zlib.Z_SYNC_FLUSH) )
146

147 148 149 150
    # if decompressed data is different from the input data, choke.
    if len(t) != len(a):
        print len(a),len(t),len(d.unused_data)
        raise TestFailed, "output of 17K doesn't match"
151

Jeremy Hylton's avatar
Jeremy Hylton committed
152 153 154 155 156 157 158
def ignore():
    """An empty function with a big string.

    Make the compression algorithm work a little harder.
    """

    """
159
LAERTES
Jeremy Hylton's avatar
Jeremy Hylton committed
160 161 162 163 164 165 166 167 168

       O, fear me not.
       I stay too long: but here my father comes.

       Enter POLONIUS

       A double blessing is a double grace,
       Occasion smiles upon a second leave.

169
LORD POLONIUS
Jeremy Hylton's avatar
Jeremy Hylton committed
170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198

       Yet here, Laertes! aboard, aboard, for shame!
       The wind sits in the shoulder of your sail,
       And you are stay'd for. There; my blessing with thee!
       And these few precepts in thy memory
       See thou character. Give thy thoughts no tongue,
       Nor any unproportioned thought his act.
       Be thou familiar, but by no means vulgar.
       Those friends thou hast, and their adoption tried,
       Grapple them to thy soul with hoops of steel;
       But do not dull thy palm with entertainment
       Of each new-hatch'd, unfledged comrade. Beware
       Of entrance to a quarrel, but being in,
       Bear't that the opposed may beware of thee.
       Give every man thy ear, but few thy voice;
       Take each man's censure, but reserve thy judgment.
       Costly thy habit as thy purse can buy,
       But not express'd in fancy; rich, not gaudy;
       For the apparel oft proclaims the man,
       And they in France of the best rank and station
       Are of a most select and generous chief in that.
       Neither a borrower nor a lender be;
       For loan oft loses both itself and friend,
       And borrowing dulls the edge of husbandry.
       This above all: to thine ownself be true,
       And it must follow, as the night the day,
       Thou canst not then be false to any man.
       Farewell: my blessing season this in thee!

199
LAERTES
Jeremy Hylton's avatar
Jeremy Hylton committed
200 201 202

       Most humbly do I take my leave, my lord.

203
LORD POLONIUS
Jeremy Hylton's avatar
Jeremy Hylton committed
204 205 206

       The time invites you; go; your servants tend.

207
LAERTES
Jeremy Hylton's avatar
Jeremy Hylton committed
208 209 210 211

       Farewell, Ophelia; and remember well
       What I have said to you.

212
OPHELIA
Jeremy Hylton's avatar
Jeremy Hylton committed
213 214 215 216

       'Tis in my memory lock'd,
       And you yourself shall keep the key of it.

217
LAERTES
Jeremy Hylton's avatar
Jeremy Hylton committed
218 219 220

       Farewell.
"""