xref: /freebsd/contrib/libarchive/libarchive/test/test_read_format_zip.c (revision 731d06abf2105cc0873fa84e972178f9f37ca760)
1 /*-
2  * Copyright (c) 2003-2007 Tim Kientzle
3  * Copyright (c) 2011 Michihiro NAKAJIMA
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
16  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18  * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
19  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  */
26 #include "test.h"
27 __FBSDID("$FreeBSD$");
28 
29 #define __LIBARCHIVE_BUILD
30 #include <archive_crc32.h>
31 
32 static
33 int extract_one(struct archive* a, struct archive_entry* ae, uint32_t crc)
34 {
35     la_ssize_t fsize, bytes_read;
36     uint8_t* buf;
37     int ret = 1;
38     uint32_t computed_crc;
39 
40     fsize = (la_ssize_t) archive_entry_size(ae);
41     buf = malloc(fsize);
42     if(buf == NULL)
43         return 1;
44 
45     bytes_read = archive_read_data(a, buf, fsize);
46     if(bytes_read != fsize) {
47         assertEqualInt(bytes_read, fsize);
48         goto fn_exit;
49     }
50 
51     computed_crc = crc32(0, buf, fsize);
52     assertEqualInt(computed_crc, crc);
53     ret = 0;
54 
55 fn_exit:
56     free(buf);
57     return ret;
58 }
59 
60 static
61 int extract_one_using_blocks(struct archive* a, int block_size, uint32_t crc)
62 {
63 	uint8_t* buf;
64 	int ret = 1;
65 	uint32_t computed_crc = 0;
66 	la_ssize_t bytes_read;
67 
68 	buf = malloc(block_size);
69 	if(buf == NULL)
70 		return 1;
71 
72 	while(1) {
73 		bytes_read = archive_read_data(a, buf, block_size);
74 		if(bytes_read == ARCHIVE_RETRY)
75 			continue;
76 		else if(bytes_read == 0)
77 			break;
78 		else if(bytes_read < 0) {
79 			/* If we're here, it means the decompressor has failed
80 			 * to properly decode test file. */
81 			assertA(0);
82 			ret = 1;
83 			goto fn_exit;
84 		} else {
85 			/* ok */
86 		}
87 
88 		computed_crc = crc32(computed_crc, buf, bytes_read);
89 	}
90 
91 	assertEqualInt(computed_crc, crc);
92 	ret = 0;
93 
94 fn_exit:
95 	free(buf);
96 	return ret;
97 }
98 
99 /*
100  * The reference file for this has been manually tweaked so that:
101  *   * file2 has length-at-end but file1 does not
102  *   * file2 has an invalid CRC
103  */
104 static void
105 verify_basic(struct archive *a, int seek_checks)
106 {
107 	struct archive_entry *ae;
108 	char *buff[128];
109 	const void *pv;
110 	size_t s;
111 	int64_t o;
112 
113 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
114         assertEqualString("ZIP 1.0 (uncompressed)", archive_format_name(a));
115 	assertEqualString("dir/", archive_entry_pathname(ae));
116 	assertEqualInt(1179604249, archive_entry_mtime(ae));
117 	assertEqualInt(0, archive_entry_size(ae));
118 	if (seek_checks)
119 		assertEqualInt(AE_IFDIR | 0755, archive_entry_mode(ae));
120 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
121 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
122 	assertEqualIntA(a, ARCHIVE_EOF,
123 	    archive_read_data_block(a, &pv, &s, &o));
124 	assertEqualInt((int)s, 0);
125 
126 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
127         assertEqualString("ZIP 2.0 (deflation)", archive_format_name(a));
128 	assertEqualString("file1", archive_entry_pathname(ae));
129 	assertEqualInt(1179604289, archive_entry_mtime(ae));
130 	if (seek_checks)
131 		assertEqualInt(AE_IFREG | 0755, archive_entry_mode(ae));
132 	assertEqualInt(18, archive_entry_size(ae));
133 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
134 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
135 	failure("archive_read_data() returns number of bytes read");
136 	if (archive_zlib_version() != NULL) {
137 		assertEqualInt(18, archive_read_data(a, buff, 19));
138 		assertEqualMem(buff, "hello\nhello\nhello\n", 18);
139 	} else {
140 		assertEqualInt(ARCHIVE_FAILED, archive_read_data(a, buff, 19));
141 		assertEqualString(archive_error_string(a),
142 		    "Unsupported ZIP compression method (deflation)");
143 		assert(archive_errno(a) != 0);
144 	}
145 
146 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
147         assertEqualString("ZIP 2.0 (deflation)", archive_format_name(a));
148 	assertEqualString("file2", archive_entry_pathname(ae));
149 	assertEqualInt(1179605932, archive_entry_mtime(ae));
150 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
151 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
152 	if (seek_checks) {
153 		assertEqualInt(AE_IFREG | 0755, archive_entry_mode(ae));
154 	}
155 	assert(archive_entry_size_is_set(ae));
156 	assertEqualInt(18, archive_entry_size(ae));
157 	if (archive_zlib_version() != NULL) {
158 		failure("file2 has a bad CRC, so read should fail and not change buff");
159 		memset(buff, 'a', 19);
160 		assertEqualInt(ARCHIVE_WARN, archive_read_data(a, buff, 19));
161 		assertEqualMem(buff, "aaaaaaaaaaaaaaaaaaa", 19);
162 	} else {
163 		assertEqualInt(ARCHIVE_FAILED, archive_read_data(a, buff, 19));
164 		assertEqualString(archive_error_string(a),
165 		    "Unsupported ZIP compression method (deflation)");
166 		assert(archive_errno(a) != 0);
167 	}
168 	assertEqualInt(ARCHIVE_EOF, archive_read_next_header(a, &ae));
169         assertEqualString("ZIP 2.0 (deflation)", archive_format_name(a));
170 	/* Verify the number of files read. */
171 	failure("the archive file has three files");
172 	assertEqualInt(3, archive_file_count(a));
173 	assertEqualIntA(a, ARCHIVE_FILTER_NONE, archive_filter_code(a, 0));
174 	assertEqualIntA(a, ARCHIVE_FORMAT_ZIP, archive_format(a));
175 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
176 	assertEqualInt(ARCHIVE_OK, archive_read_free(a));
177 }
178 
179 static void
180 test_basic(void)
181 {
182 	const char *refname = "test_read_format_zip.zip";
183 	struct archive *a;
184 	char *p;
185 	size_t s;
186 
187 	extract_reference_file(refname);
188 
189 	/* Verify with seeking reader. */
190 	assert((a = archive_read_new()) != NULL);
191 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_filter_all(a));
192 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
193 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 10240));
194 	verify_basic(a, 1);
195 
196 	/* Verify with streaming reader. */
197 	p = slurpfile(&s, refname);
198 	assert((a = archive_read_new()) != NULL);
199 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_filter_all(a));
200 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
201 	assertEqualIntA(a, ARCHIVE_OK, read_open_memory(a, p, s, 31));
202 	verify_basic(a, 0);
203 	free(p);
204 }
205 
206 /*
207  * Read Info-ZIP New Unix Extra Field 0x7875 "ux".
208  *  Currently stores Unix UID/GID up to 32 bits.
209  */
210 static void
211 verify_info_zip_ux(struct archive *a, int seek_checks)
212 {
213 	struct archive_entry *ae;
214 	char *buff[128];
215 
216 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
217 	assertEqualString("file1", archive_entry_pathname(ae));
218 	assertEqualInt(1300668680, archive_entry_mtime(ae));
219 	assertEqualInt(18, archive_entry_size(ae));
220 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
221 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
222 	if (seek_checks)
223 		assertEqualInt(AE_IFREG | 0644, archive_entry_mode(ae));
224 	failure("zip reader should read Info-ZIP New Unix Extra Field");
225 	assertEqualInt(1001, archive_entry_uid(ae));
226 	assertEqualInt(1001, archive_entry_gid(ae));
227 	if (archive_zlib_version() != NULL) {
228 		failure("archive_read_data() returns number of bytes read");
229 		assertEqualInt(18, archive_read_data(a, buff, 19));
230 		assertEqualMem(buff, "hello\nhello\nhello\n", 18);
231 	} else {
232 		assertEqualInt(ARCHIVE_FAILED, archive_read_data(a, buff, 19));
233 		assertEqualString(archive_error_string(a),
234 		    "Unsupported ZIP compression method (deflation)");
235 		assert(archive_errno(a) != 0);
236 	}
237 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
238 
239 	/* Verify the number of files read. */
240 	failure("the archive file has just one file");
241 	assertEqualInt(1, archive_file_count(a));
242 
243 	assertEqualIntA(a, ARCHIVE_FILTER_NONE, archive_filter_code(a, 0));
244 	assertEqualIntA(a, ARCHIVE_FORMAT_ZIP, archive_format(a));
245 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
246 	assertEqualInt(ARCHIVE_OK, archive_read_free(a));
247 }
248 
249 static void
250 test_info_zip_ux(void)
251 {
252 	const char *refname = "test_read_format_zip_ux.zip";
253 	struct archive *a;
254 	char *p;
255 	size_t s;
256 
257 	extract_reference_file(refname);
258 
259 	/* Verify with seeking reader. */
260 	assert((a = archive_read_new()) != NULL);
261 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_filter_all(a));
262 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
263 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 10240));
264 	verify_info_zip_ux(a, 1);
265 
266 	/* Verify with streaming reader. */
267 	p = slurpfile(&s, refname);
268 	assert((a = archive_read_new()) != NULL);
269 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_filter_all(a));
270 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
271 	assertEqualIntA(a, ARCHIVE_OK, read_open_memory(a, p, s, 108));
272 	verify_info_zip_ux(a, 0);
273 	free(p);
274 }
275 
276 /*
277  * Verify that test_read_extract correctly works with
278  * Zip entries that use length-at-end.
279  */
280 static void
281 verify_extract_length_at_end(struct archive *a, int seek_checks)
282 {
283 	struct archive_entry *ae;
284 
285 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
286 
287 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
288 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
289 	assertEqualString("hello.txt", archive_entry_pathname(ae));
290 	if (seek_checks) {
291 		assertEqualInt(AE_IFREG | 0644, archive_entry_mode(ae));
292 		assert(archive_entry_size_is_set(ae));
293 		assertEqualInt(6, archive_entry_size(ae));
294 	} else {
295 		assert(!archive_entry_size_is_set(ae));
296 		assertEqualInt(0, archive_entry_size(ae));
297 	}
298 
299 	if (archive_zlib_version() != NULL) {
300 		assertEqualIntA(a, ARCHIVE_OK, archive_read_extract(a, ae, 0));
301 		assertFileContents("hello\x0A", 6, "hello.txt");
302 	} else {
303 		assertEqualIntA(a, ARCHIVE_FAILED, archive_read_extract(a, ae, 0));
304 		assertEqualString(archive_error_string(a),
305 		    "Unsupported ZIP compression method (deflation)");
306 		assert(archive_errno(a) != 0);
307 	}
308 
309 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
310 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
311 }
312 
313 static void
314 test_extract_length_at_end(void)
315 {
316 	const char *refname = "test_read_format_zip_length_at_end.zip";
317 	char *p;
318 	size_t s;
319 	struct archive *a;
320 
321 	extract_reference_file(refname);
322 
323 	/* Verify extraction with seeking reader. */
324 	assert((a = archive_read_new()) != NULL);
325 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_filter_all(a));
326 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
327 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 10240));
328 	verify_extract_length_at_end(a, 1);
329 
330 	/* Verify extraction with streaming reader. */
331 	p = slurpfile(&s, refname);
332 	assert((a = archive_read_new()) != NULL);
333 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_filter_all(a));
334 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
335 	assertEqualIntA(a, ARCHIVE_OK, read_open_memory(a, p, s, 108));
336 	verify_extract_length_at_end(a, 0);
337 	free(p);
338 }
339 
340 static void
341 test_symlink(void)
342 {
343 	const char *refname = "test_read_format_zip_symlink.zip";
344 	char *p;
345 	size_t s;
346 	struct archive *a;
347 	struct archive_entry *ae;
348 
349 	extract_reference_file(refname);
350 	p = slurpfile(&s, refname);
351 
352 	/* Symlinks can only be extracted with the seeking reader. */
353 	assert((a = archive_read_new()) != NULL);
354 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
355 	assertEqualIntA(a, ARCHIVE_OK, read_open_memory_seek(a, p, s, 1));
356 
357 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
358 	assertEqualString("file", archive_entry_pathname(ae));
359 	assertEqualInt(AE_IFREG, archive_entry_filetype(ae));
360 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
361 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
362 
363 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
364 	assertEqualString("symlink", archive_entry_pathname(ae));
365 	assertEqualInt(AE_IFLNK, archive_entry_filetype(ae));
366 	assertEqualInt(0, archive_entry_size(ae));
367 	assertEqualString("file", archive_entry_symlink(ae));
368 	assertEqualInt(archive_entry_is_encrypted(ae), 0);
369 	assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0);
370 
371 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
372 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
373 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
374 
375 	free(p);
376 }
377 
378 DEFINE_TEST(test_read_format_zip)
379 {
380 	test_basic();
381 	test_info_zip_ux();
382 	test_extract_length_at_end();
383 	test_symlink();
384 }
385 
386 DEFINE_TEST(test_read_format_zip_ppmd_one_file)
387 {
388 	const char *refname = "test_read_format_zip_ppmd8.zipx";
389 	struct archive *a;
390 	struct archive_entry *ae;
391 
392 	extract_reference_file(refname);
393 
394 	assert((a = archive_read_new()) != NULL);
395 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
396 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
397 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
398 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
399 	assertEqualString("vimrc", archive_entry_pathname(ae));
400 	assertEqualIntA(a, 0, extract_one(a, ae, 0xBA8E3BAA));
401 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
402 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
403 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
404 }
405 
406 DEFINE_TEST(test_read_format_zip_ppmd_one_file_blockread)
407 {
408 	const char *refname = "test_read_format_zip_ppmd8.zipx";
409 	struct archive *a;
410 	struct archive_entry *ae;
411 
412 	extract_reference_file(refname);
413 
414 	assert((a = archive_read_new()) != NULL);
415 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
416 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
417 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
418 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
419 	assertEqualString("vimrc", archive_entry_pathname(ae));
420 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0xBA8E3BAA));
421 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
422 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
423 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
424 }
425 
426 DEFINE_TEST(test_read_format_zip_ppmd_multi)
427 {
428 	const char *refname = "test_read_format_zip_ppmd8_multi.zipx";
429 	struct archive *a;
430 	struct archive_entry *ae;
431 
432 	extract_reference_file(refname);
433 
434 	assert((a = archive_read_new()) != NULL);
435 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
436 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
437 
438 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
439 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
440 	assertEqualString("smartd.conf", archive_entry_pathname(ae));
441 	assertEqualIntA(a, 0, extract_one(a, ae, 0x8DD7379E));
442 
443 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
444 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
445 	assertEqualString("ts.conf", archive_entry_pathname(ae));
446 	assertEqualIntA(a, 0, extract_one(a, ae, 0x7AE59B31));
447 
448 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
449 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
450 	assertEqualString("vimrc", archive_entry_pathname(ae));
451 	assertEqualIntA(a, 0, extract_one(a, ae, 0xBA8E3BAA));
452 
453 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
454 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
455 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
456 }
457 
458 DEFINE_TEST(test_read_format_zip_ppmd_multi_blockread)
459 {
460 	const char *refname = "test_read_format_zip_ppmd8_multi.zipx";
461 	struct archive *a;
462 	struct archive_entry *ae;
463 
464 	extract_reference_file(refname);
465 
466 	assert((a = archive_read_new()) != NULL);
467 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
468 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
469 
470 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
471 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
472 	assertEqualString("smartd.conf", archive_entry_pathname(ae));
473 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 12, 0x8DD7379E));
474 
475 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
476 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
477 	assertEqualString("ts.conf", archive_entry_pathname(ae));
478 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0x7AE59B31));
479 
480 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
481 	assertEqualString("ZIP 6.3 (ppmd-1)", archive_format_name(a));
482 	assertEqualString("vimrc", archive_entry_pathname(ae));
483 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 14, 0xBA8E3BAA));
484 
485 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
486 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
487 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
488 }
489 
490 DEFINE_TEST(test_read_format_zip_lzma_one_file)
491 {
492 	const char *refname = "test_read_format_zip_lzma.zipx";
493 	struct archive *a;
494 	struct archive_entry *ae;
495 
496 	extract_reference_file(refname);
497 
498 	assert((a = archive_read_new()) != NULL);
499 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
500 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
501 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
502 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
503 	assertEqualString("vimrc", archive_entry_pathname(ae));
504 	assertEqualIntA(a, 0, extract_one(a, ae, 0xBA8E3BAA));
505 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
506 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
507 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
508 }
509 
510 DEFINE_TEST(test_read_format_zip_lzma_one_file_blockread)
511 {
512 	const char *refname = "test_read_format_zip_lzma.zipx";
513 	struct archive *a;
514 	struct archive_entry *ae;
515 
516 	extract_reference_file(refname);
517 
518 	assert((a = archive_read_new()) != NULL);
519 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
520 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
521 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
522 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
523 	assertEqualString("vimrc", archive_entry_pathname(ae));
524 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0xBA8E3BAA));
525 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
526 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
527 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
528 }
529 
530 DEFINE_TEST(test_read_format_zip_lzma_multi)
531 {
532 	const char *refname = "test_read_format_zip_lzma_multi.zipx";
533 	struct archive *a;
534 	struct archive_entry *ae;
535 
536 	extract_reference_file(refname);
537 
538 	assert((a = archive_read_new()) != NULL);
539 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
540 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
541 
542 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
543 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
544 	assertEqualString("smartd.conf", archive_entry_pathname(ae));
545 	assertEqualIntA(a, 0, extract_one(a, ae, 0x8DD7379E));
546 
547 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
548 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
549 	assertEqualString("ts.conf", archive_entry_pathname(ae));
550 	assertEqualIntA(a, 0, extract_one(a, ae, 0x7AE59B31));
551 
552 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
553 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
554 	assertEqualString("vimrc", archive_entry_pathname(ae));
555 	assertEqualIntA(a, 0, extract_one(a, ae, 0xBA8E3BAA));
556 
557 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
558 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
559 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
560 }
561 
562 DEFINE_TEST(test_read_format_zip_lzma_multi_blockread)
563 {
564 	const char *refname = "test_read_format_zip_lzma_multi.zipx";
565 	struct archive *a;
566 	struct archive_entry *ae;
567 
568 	extract_reference_file(refname);
569 
570 	assert((a = archive_read_new()) != NULL);
571 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
572 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
573 
574 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
575 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
576 	assertEqualString("smartd.conf", archive_entry_pathname(ae));
577 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 12, 0x8DD7379E));
578 
579 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
580 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
581 	assertEqualString("ts.conf", archive_entry_pathname(ae));
582 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0x7AE59B31));
583 
584 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
585 	assertEqualString("ZIP 6.3 (lzma)", archive_format_name(a));
586 	assertEqualString("vimrc", archive_entry_pathname(ae));
587 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 14, 0xBA8E3BAA));
588 
589 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
590 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
591 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
592 }
593 
594 
595 DEFINE_TEST(test_read_format_zip_bzip2_one_file)
596 {
597 	const char *refname = "test_read_format_zip_bzip2.zipx";
598 	struct archive *a;
599 	struct archive_entry *ae;
600 
601 	extract_reference_file(refname);
602 
603 	assert((a = archive_read_new()) != NULL);
604 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
605 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
606 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
607 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
608 	assertEqualString("vimrc", archive_entry_pathname(ae));
609 	assertEqualIntA(a, 0, extract_one(a, ae, 0xBA8E3BAA));
610 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
611 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
612 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
613 }
614 
615 DEFINE_TEST(test_read_format_zip_bzip2_one_file_blockread)
616 {
617 	const char *refname = "test_read_format_zip_bzip2.zipx";
618 	struct archive *a;
619 	struct archive_entry *ae;
620 
621 	extract_reference_file(refname);
622 
623 	assert((a = archive_read_new()) != NULL);
624 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
625 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
626 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
627 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
628 	assertEqualString("vimrc", archive_entry_pathname(ae));
629 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0xBA8E3BAA));
630 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
631 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
632 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
633 }
634 
635 DEFINE_TEST(test_read_format_zip_bzip2_multi)
636 {
637 	const char *refname = "test_read_format_zip_bzip2_multi.zipx";
638 	struct archive *a;
639 	struct archive_entry *ae;
640 
641 	extract_reference_file(refname);
642 
643 	assert((a = archive_read_new()) != NULL);
644 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
645 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
646 
647 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
648 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
649 	assertEqualString("smartd.conf", archive_entry_pathname(ae));
650 	assertEqualIntA(a, 0, extract_one(a, ae, 0x8DD7379E));
651 
652 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
653 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
654 	assertEqualString("ts.conf", archive_entry_pathname(ae));
655 	assertEqualIntA(a, 0, extract_one(a, ae, 0x7AE59B31));
656 
657 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
658 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
659 	assertEqualString("vimrc", archive_entry_pathname(ae));
660 	assertEqualIntA(a, 0, extract_one(a, ae, 0xBA8E3BAA));
661 
662 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
663 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
664 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
665 }
666 
667 DEFINE_TEST(test_read_format_zip_bzip2_multi_blockread)
668 {
669 	const char *refname = "test_read_format_zip_bzip2_multi.zipx";
670 	struct archive *a;
671 	struct archive_entry *ae;
672 
673 	extract_reference_file(refname);
674 
675 	assert((a = archive_read_new()) != NULL);
676 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
677 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
678 
679 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
680 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
681 	assertEqualString("smartd.conf", archive_entry_pathname(ae));
682 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 12, 0x8DD7379E));
683 
684 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
685 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
686 	assertEqualString("ts.conf", archive_entry_pathname(ae));
687 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0x7AE59B31));
688 
689 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
690 	assertEqualString("ZIP 4.6 (bzip)", archive_format_name(a));
691 	assertEqualString("vimrc", archive_entry_pathname(ae));
692 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 14, 0xBA8E3BAA));
693 
694 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
695 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
696 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
697 }
698 
699 DEFINE_TEST(test_read_format_zip_xz_multi)
700 {
701 	const char *refname = "test_read_format_zip_xz_multi.zipx";
702 	struct archive *a;
703 	struct archive_entry *ae;
704 
705 	extract_reference_file(refname);
706 
707 	assert((a = archive_read_new()) != NULL);
708 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
709 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
710 
711 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
712 	assertEqualString("ZIP 2.0 (xz)", archive_format_name(a));
713 	assertEqualString("bash.bashrc", archive_entry_pathname(ae));
714 	assertEqualIntA(a, 0, extract_one(a, ae, 0xF751B8C9));
715 
716 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
717 	assertEqualString("ZIP 2.0 (xz)", archive_format_name(a));
718 	assertEqualString("pacman.conf", archive_entry_pathname(ae));
719 	assertEqualIntA(a, 0, extract_one(a, ae, 0xB20B7F88));
720 
721 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
722 	assertEqualString("ZIP 2.0 (xz)", archive_format_name(a));
723 	assertEqualString("profile", archive_entry_pathname(ae));
724 	assertEqualIntA(a, 0, extract_one(a, ae, 0x2329F054));
725 
726 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
727 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
728 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
729 }
730 
731 DEFINE_TEST(test_read_format_zip_xz_multi_blockread)
732 {
733 	const char *refname = "test_read_format_zip_xz_multi.zipx";
734 	struct archive *a;
735 	struct archive_entry *ae;
736 
737 	extract_reference_file(refname);
738 
739 	assert((a = archive_read_new()) != NULL);
740 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
741 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
742 
743 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
744 	assertEqualString("ZIP 2.0 (xz)", archive_format_name(a));
745 	assertEqualString("bash.bashrc", archive_entry_pathname(ae));
746 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 12, 0xF751B8C9));
747 
748 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
749 	assertEqualString("ZIP 2.0 (xz)", archive_format_name(a));
750 	assertEqualString("pacman.conf", archive_entry_pathname(ae));
751 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 13, 0xB20B7F88));
752 
753 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
754 	assertEqualString("ZIP 2.0 (xz)", archive_format_name(a));
755 	assertEqualString("profile", archive_entry_pathname(ae));
756 	assertEqualIntA(a, 0, extract_one_using_blocks(a, 14, 0x2329F054));
757 
758 	assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
759 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
760 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
761 }
762 
763 DEFINE_TEST(test_read_format_zip_ppmd8_crash_1)
764 {
765 	const char *refname = "test_read_format_zip_ppmd8_crash_2.zipx";
766 	struct archive *a;
767 	struct archive_entry *ae;
768 	char buf[64];
769 
770 	extract_reference_file(refname);
771 
772 	assert((a = archive_read_new()) != NULL);
773 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
774 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 100));
775 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
776 
777 	/* This file shouldn't be properly decompressed, because it's invalid.
778 	 * However, unpacker should return an error during unpacking. Without the
779 	 * proper fix, the unpacker was entering an unlimited loop. */
780 	assertEqualIntA(a, ARCHIVE_FATAL, archive_read_data(a, buf, 1));
781 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
782 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
783 }
784 
785 DEFINE_TEST(test_read_format_zip_bz2_hang_on_invalid)
786 {
787 	const char *refname = "test_read_format_zip_bz2_hang.zip";
788 	struct archive *a;
789 	struct archive_entry *ae;
790 	char buf[8];
791 
792 	extract_reference_file(refname);
793 
794 	assert((a = archive_read_new()) != NULL);
795 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
796 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
797 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
798 
799 	/* The file `refname` is invalid in this case, so this call should fail.
800 	 * But it shouldn't crash. */
801 	assertEqualIntA(a, ARCHIVE_FATAL, archive_read_data(a, buf, 64));
802 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
803 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
804 }
805 
806 DEFINE_TEST(test_read_format_zip_ppmd8_crash_2)
807 {
808 	const char *refname = "test_read_format_zip_ppmd8_crash_2.zipx";
809 	struct archive *a;
810 	struct archive_entry *ae;
811 	char buf[64];
812 
813 	extract_reference_file(refname);
814 
815 	assert((a = archive_read_new()) != NULL);
816 	assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_zip(a));
817 	assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, refname, 37));
818 	assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
819 
820 	/* The file `refname` is invalid in this case, so this call should fail.
821 	 * But it shouldn't crash. */
822 	assertEqualIntA(a, ARCHIVE_FATAL, archive_read_data(a, buf, 64));
823 	assertEqualIntA(a, ARCHIVE_OK, archive_read_close(a));
824 	assertEqualIntA(a, ARCHIVE_OK, archive_read_free(a));
825 }
826