1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
|
# gemato: compressed file tests
# vim:fileencoding=utf-8
# (c) 2017 Michał Górny
# Licensed under the terms of 2-clause BSD license
import base64
import io
import unittest
import gemato.compression
TEST_STRING = b'The quick brown fox jumps over the lazy dog'
class GzipCompressionTest(unittest.TestCase):
BASE64 = b'''
H4sIACbJ8FkAAwvJSFUoLM1MzlZIKsovz1NIy69QyCrNLShWyC9LLVIoAUrnJFZVKqTkpwMAOaNP
QSsAAAA=
'''
EMPTY_BASE64 = b'''
H4sIACbJ8FkAAwMAAAAAAAAAAAA=
'''
SPLIT_BASE64 = b'''
H4sIACbJ8FkAAwvJSFUoLM1MzlZIKsovz1NIy69QAADidbCIFAAAAB+LCAAmyfBZAAPLKs0tKFbI
L0stUijJSFXISayqVEjJTwcAlGd4GBcAAAA=
'''
def test_gzip(self):
with io.BytesIO(base64.b64decode(self.BASE64)) as f:
with gemato.compression.open_compressed_file('gz', f) as gz:
self.assertEqual(gz.read(), TEST_STRING)
def test_gzip_empty(self):
with io.BytesIO(base64.b64decode(self.EMPTY_BASE64)) as f:
with gemato.compression.open_compressed_file('gz', f) as gz:
self.assertEqual(gz.read(), b'')
def test_gzip_split(self):
with io.BytesIO(base64.b64decode(self.SPLIT_BASE64)) as f:
with gemato.compression.open_compressed_file('gz', f) as gz:
self.assertEqual(gz.read(), TEST_STRING)
class Bzip2CompressionTest(unittest.TestCase):
BASE64 = b'''
QlpoOTFBWSZTWUWd7mEAAAQTgEAABAA////wIAEABTQAAAGigAAAAEBoLtBqVm1CpOmzyfUXAw5P
HXD0304jMvvfF3JFOFCQRZ3uYQ==
'''
EMPTY_BASE64 = b'''
QlpoORdyRThQkAAAAAA=
'''
SPLIT_BASE64 = b'''
QlpoOTFBWSZTWQgcCrAAAAITgEAABAAbabLAIABBEaDR6jT9UoAAAbUXZJ48gnMg3xdyRThQkAgc
CrBCWmg5MUFZJlNZOxleaAAABRGAQAAm1t8wIACAUaNDRtTaSgAAAcAcViIdSEhzctM/F3JFOFCQ
OxleaA==
'''
def test_bzip2(self):
with io.BytesIO(base64.b64decode(self.BASE64)) as f:
try:
with gemato.compression.open_compressed_file('bz2', f) as bz2:
self.assertEqual(bz2.read(), TEST_STRING)
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('bz2 compression unsupported')
def test_bzip2_empty(self):
with io.BytesIO(base64.b64decode(self.EMPTY_BASE64)) as f:
try:
with gemato.compression.open_compressed_file('bz2', f) as bz2:
self.assertEqual(bz2.read(), b'')
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('bz2 compression unsupported')
def test_bzip2_split(self):
with io.BytesIO(base64.b64decode(self.SPLIT_BASE64)) as f:
try:
with gemato.compression.open_compressed_file('bz2', f) as bz2:
self.assertEqual(bz2.read(), TEST_STRING)
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('bz2 compression unsupported')
class LZMALegacyCompressionTest(unittest.TestCase):
BASE64 = b'''
XQAAAAT//////////wAqGgiiAyVm8Ut4xaIF/y7m2dIgGq00+OId6EE2+twGabs85BA0Jwnrs2bs
Ghcv//zOkAA=
'''
EMPTY_BASE64 = b'''
XQAAAAT//////////wCD//v//8AAAAA=
'''
SPLIT_BASE64 = b'''
XQAAAAT//////////wAqGgiiAyVm8Ut4xaIF/y7m2dIgGq1EvQql//X0QABdAAAABP//////////
ADUdSd6zBOkOpekGFH46zix9wE9VT65OVeV479//7uUAAA==
'''
def test_lzma_legacy(self):
with io.BytesIO(base64.b64decode(self.BASE64)) as f:
try:
with gemato.compression.open_compressed_file('lzma', f) as lzma:
self.assertEqual(lzma.read(), TEST_STRING)
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('lzma compression unsupported')
def test_lzma_legacy_empty(self):
with io.BytesIO(base64.b64decode(self.EMPTY_BASE64)) as f:
try:
with gemato.compression.open_compressed_file('lzma', f) as lzma:
self.assertEqual(lzma.read(), b'')
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('lzma compression unsupported')
def test_lzma_legacy_split(self):
with io.BytesIO(base64.b64decode(self.SPLIT_BASE64)) as f:
try:
with gemato.compression.open_compressed_file('lzma', f) as lzma:
self.assertEqual(lzma.read(), TEST_STRING)
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('lzma compression unsupported')
class XZCompressionTest(unittest.TestCase):
BASE64 = b'''
/Td6WFoAAATm1rRGAgAhARwAAAAQz1jMAQAqVGhlIHF1aWNrIGJyb3duIGZveCBqdW1wcyBvdmVy
IHRoZSBsYXp5IGRvZwAAxKFK5cK4XlsAAUMrrVBuVx+2830BAAAAAARZWg==
'''
EMPTY_BASE64 = b'''
/Td6WFoAAATm1rRGAAAAABzfRCEftvN9AQAAAAAEWVo=
'''
SPLIT_BASE64 = b'''
/Td6WFoAAATm1rRGAgAhARwAAAAQz1jMAQATVGhlIHF1aWNrIGJyb3duIGZveCAAIEFC5acaLXcA
ASwU+AptAx+2830BAAAAAARZWv03elhaAAAE5ta0RgIAIQEcAAAAEM9YzAEAFmp1bXBzIG92ZXIg
dGhlIGxhenkgZG9nAADjZCTmHjHqggABLxeBCEmxH7bzfQEAAAAABFla
'''
def test_xz(self):
with io.BytesIO(base64.b64decode(self.BASE64)) as f:
try:
with gemato.compression.open_compressed_file('xz', f) as xz:
self.assertEqual(xz.read(), TEST_STRING)
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('xz compression unsupported')
def test_xz_empty(self):
with io.BytesIO(base64.b64decode(self.EMPTY_BASE64)) as f:
try:
with gemato.compression.open_compressed_file('xz', f) as xz:
self.assertEqual(xz.read(), b'')
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('xz compression unsupported')
def test_xz_split(self):
with io.BytesIO(base64.b64decode(self.SPLIT_BASE64)) as f:
try:
with gemato.compression.open_compressed_file('xz', f) as xz:
self.assertEqual(xz.read(), TEST_STRING)
except gemato.exceptions.UnsupportedCompression:
raise unittest.SkipTest('xz compression unsupported')
|