1 /*- 2 * Copyright (c) 2019 Martin Matuska 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR 15 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 16 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 17 * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT, 18 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 19 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 20 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 21 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 23 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 24 */ 25 #include "test.h" 26 27 /* Read archive with digests in PackInfo */ 28 DEFINE_TEST(test_read_format_7zip_packinfo_digests) 29 { 30 struct archive_entry *ae; 31 struct archive *a; 32 char buff[4]; 33 const char *refname = "test_read_format_7zip_packinfo_digests.7z"; 34 35 extract_reference_file(refname); 36 assert((a = archive_read_new()) != NULL); 37 if (ARCHIVE_OK != archive_read_support_filter_xz(a)) { 38 skipping("7zip:lzma decoding is not supported on this " 39 "platform"); 40 } else { 41 assertEqualIntA(a, ARCHIVE_OK, 42 archive_read_support_filter_all(a)); 43 assertEqualIntA(a, ARCHIVE_OK, 44 archive_read_support_format_all(a)); 45 assertEqualIntA(a, ARCHIVE_OK, 46 archive_read_open_filename(a, refname, 10240)); 47 48 /* Verify regular file1. */ 49 assertEqualIntA(a, ARCHIVE_OK, 50 archive_read_next_header(a, &ae)); 51 assertEqualInt((AE_IFREG | 0644), archive_entry_mode(ae)); 52 assertEqualString("a.txt", archive_entry_pathname(ae)); 53 assertEqualInt(1576808819, archive_entry_mtime(ae)); 54 assertEqualInt(4, archive_entry_size(ae)); 55 assertEqualInt(archive_entry_is_encrypted(ae), 0); 56 assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0); 57 assertEqualInt(4, archive_read_data(a, buff, sizeof(buff))); 58 assertEqualMem(buff, "aaa\n", 4); 59 60 /* Verify regular file2. */ 61 assertEqualIntA(a, ARCHIVE_OK, 62 archive_read_next_header(a, &ae)); 63 assertEqualInt((AE_IFREG | 0644), archive_entry_mode(ae)); 64 assertEqualString("b.txt", archive_entry_pathname(ae)); 65 assertEqualInt(1576808819, archive_entry_mtime(ae)); 66 assertEqualInt(4, archive_entry_size(ae)); 67 assertEqualInt(archive_entry_is_encrypted(ae), 0); 68 assertEqualIntA(a, archive_read_has_encrypted_entries(a), 0); 69 assertEqualInt(4, archive_read_data(a, buff, sizeof(buff))); 70 assertEqualMem(buff, "bbb\n", 4); 71 72 assertEqualInt(2, archive_file_count(a)); 73 74 /* End of archive. */ 75 assertEqualIntA(a, ARCHIVE_EOF, 76 archive_read_next_header(a, &ae)); 77 78 /* Verify archive format. */ 79 assertEqualIntA(a, ARCHIVE_FILTER_NONE, 80 archive_filter_code(a, 0)); 81 assertEqualIntA(a, ARCHIVE_FORMAT_7ZIP, 82 archive_format(a)); 83 84 /* Close the archive. */ 85 assertEqualInt(ARCHIVE_OK, archive_read_close(a)); 86 } 87 assertEqualInt(ARCHIVE_OK, archive_read_free(a)); 88 } 89