blob: 0f8e03e0a45cb3b49391b3fa6c78108b3467ff74 [file] [log] [blame]
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +00001#! /usr/bin/env python
2"""Test script for the gzip module.
3"""
4
5import unittest
6from test import test_support
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +00007import sys, os
Guido van Rossum3b0a3292002-08-09 16:38:32 +00008import gzip
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +00009
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +000010
11data1 = """ int length=DEFAULTALLOC, err = Z_OK;
12 PyObject *RetVal;
13 int flushmode = Z_FINISH;
14 unsigned long start_total_out;
15
16"""
17
18data2 = """/* zlibmodule.c -- gzip-compatible data compression */
Neal Norwitz014f1032004-07-29 03:55:56 +000019/* See http://www.gzip.org/zlib/
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +000020/* See http://www.winimage.com/zLibDll for Windows */
21"""
22
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +000023
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000024class TestGzip(unittest.TestCase):
25 filename = test_support.TESTFN
Tim Peters5cfb05e2004-07-27 21:02:02 +000026
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000027 def setUp (self):
28 pass
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +000029
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000030 def tearDown (self):
31 try:
32 os.unlink(self.filename)
33 except os.error:
34 pass
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +000035
Andrew M. Kuchling85ab7382000-07-29 20:18:34 +000036
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000037 def test_write (self):
38 f = gzip.GzipFile(self.filename, 'wb') ; f.write(data1 * 50)
Andrew M. Kuchling85ab7382000-07-29 20:18:34 +000039
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000040 # Try flush and fileno.
41 f.flush()
42 f.fileno()
43 if hasattr(os, 'fsync'):
44 os.fsync(f.fileno())
45 f.close()
Andrew M. Kuchling85ab7382000-07-29 20:18:34 +000046
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000047 def test_read(self):
48 self.test_write()
49 # Try reading.
50 f = gzip.GzipFile(self.filename, 'r') ; d = f.read() ; f.close()
51 self.assertEqual(d, data1*50)
Andrew M. Kuchling85ab7382000-07-29 20:18:34 +000052
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000053 def test_append(self):
54 self.test_write()
55 # Append to the previous file
56 f = gzip.GzipFile(self.filename, 'ab') ; f.write(data2 * 15) ; f.close()
Andrew M. Kuchling85ab7382000-07-29 20:18:34 +000057
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000058 f = gzip.GzipFile(self.filename, 'rb') ; d = f.read() ; f.close()
59 self.assertEqual(d, (data1*50) + (data2*15))
Andrew M. Kuchling85ab7382000-07-29 20:18:34 +000060
Andrew M. Kuchling01cb47b2005-06-09 14:19:32 +000061 def test_many_append(self):
62 # Bug #1074261 was triggered when reading a file that contained
63 # many, many members. Create such a file and verify that reading it
64 # works.
65 f = gzip.open(self.filename, 'wb', 9)
66 f.write('a')
67 f.close()
68 for i in range(0,200):
69 f = gzip.open(self.filename, "ab", 9) # append
70 f.write('a')
71 f.close()
72
73 # Try reading the file
74 zgfile = gzip.open(self.filename, "rb")
75 contents = ""
76 while 1:
77 ztxt = zgfile.read(8192)
78 contents += ztxt
79 if not ztxt: break
80 zgfile.close()
81 self.assertEquals(contents, 'a'*201)
82
83
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000084 def test_readline(self):
85 self.test_write()
86 # Try .readline() with varying line lengths
Martin v. Löwis8cc965c2001-08-09 07:21:56 +000087
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000088 f = gzip.GzipFile(self.filename, 'rb')
89 line_length = 0
90 while 1:
91 L = f.readline(line_length)
92 if L == "" and line_length != 0: break
93 self.assert_(len(L) <= line_length)
94 line_length = (line_length + 1) % 50
95 f.close()
Martin v. Löwis8cc965c2001-08-09 07:21:56 +000096
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +000097 def test_readlines(self):
98 self.test_write()
99 # Try .readlines()
Andrew M. Kuchling605ebdd1999-03-25 21:50:27 +0000100
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +0000101 f = gzip.GzipFile(self.filename, 'rb')
102 L = f.readlines()
103 f.close()
Skip Montanaro12424bc2002-05-23 01:43:05 +0000104
Andrew M. Kuchlinga6f68e12005-06-09 14:12:36 +0000105 f = gzip.GzipFile(self.filename, 'rb')
106 while 1:
107 L = f.readlines(150)
108 if L == []: break
109 f.close()
110
111 def test_seek_read(self):
112 self.test_write()
113 # Try seek, read test
114
115 f = gzip.GzipFile(self.filename)
116 while 1:
117 oldpos = f.tell()
118 line1 = f.readline()
119 if not line1: break
120 newpos = f.tell()
121 f.seek(oldpos) # negative seek
122 if len(line1)>10:
123 amount = 10
124 else:
125 amount = len(line1)
126 line2 = f.read(amount)
127 self.assertEqual(line1[:amount], line2)
128 f.seek(newpos) # positive seek
129 f.close()
130
131 def test_seek_write(self):
132 # Try seek, write test
133 f = gzip.GzipFile(self.filename, 'w')
134 for pos in range(0, 256, 16):
135 f.seek(pos)
136 f.write('GZ\n')
137 f.close()
138
139 def test_mode(self):
140 self.test_write()
141 f = gzip.GzipFile(self.filename, 'r')
142 self.assertEqual(f.myfileobj.mode, 'rb')
143 f.close()
144
145def test_main(verbose=None):
146 test_support.run_unittest(TestGzip)
147
148if __name__ == "__main__":
149 test_main(verbose=True)