diff options
Diffstat (limited to 'tests/tar_ustar.c')
-rw-r--r-- | tests/tar_ustar.c | 143 |
1 files changed, 15 insertions, 128 deletions
diff --git a/tests/tar_ustar.c b/tests/tar_ustar.c index b794e30..8ca1b36 100644 --- a/tests/tar_ustar.c +++ b/tests/tar_ustar.c @@ -4,15 +4,7 @@ * * Copyright (C) 2019 David Oberhollenzer <goliath@infraroot.at> */ -#include "config.h" - -#include "tar.h" -#include "test.h" - -#define STR(x) #x -#define STRVALUE(x) STR(x) - -#define TEST_PATH STRVALUE(TESTPATH) +#include "test_tar.h" static const char *filename = "012345678901234567890123456789/012345678901234567890123456789/" @@ -21,126 +13,21 @@ static const char *filename = int main(void) { - tar_header_decoded_t hdr; - char buffer[6]; - FILE *fp; - TEST_ASSERT(chdir(TEST_PATH) == 0); - fp = test_open_read("format-acceptance/ustar.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 01750); - TEST_EQUAL_UI(hdr.sb.st_gid, 01750); - TEST_EQUAL_UI(hdr.sb.st_size, 5); - TEST_EQUAL_UI(hdr.sb.st_mtime, 1542905892); - TEST_EQUAL_UI(hdr.mtime, 1542905892); - TEST_STR_EQUAL(hdr.name, "input.txt"); - TEST_ASSERT(!hdr.unknown_record); - TEST_ASSERT(read_retry("data0", fp, buffer, 5) == 0); - buffer[5] = '\0'; - TEST_STR_EQUAL(buffer, "test\n"); - clear_header(&hdr); - fclose(fp); - - fp = test_open_read("format-acceptance/ustar-pre-posix.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 01750); - TEST_EQUAL_UI(hdr.sb.st_gid, 01750); - TEST_EQUAL_UI(hdr.sb.st_size, 5); - TEST_EQUAL_UI(hdr.sb.st_mtime, 1542905892); - TEST_EQUAL_UI(hdr.mtime, 1542905892); - TEST_STR_EQUAL(hdr.name, "input.txt"); - TEST_ASSERT(!hdr.unknown_record); - TEST_ASSERT(read_retry("data1", fp, buffer, 5) == 0); - buffer[5] = '\0'; - TEST_STR_EQUAL(buffer, "test\n"); - clear_header(&hdr); - fclose(fp); - - fp = test_open_read("format-acceptance/v7.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 01750); - TEST_EQUAL_UI(hdr.sb.st_gid, 01750); - TEST_EQUAL_UI(hdr.sb.st_size, 5); - TEST_EQUAL_UI(hdr.sb.st_mtime, 1542905892); - TEST_EQUAL_UI(hdr.mtime, 1542905892); - TEST_STR_EQUAL(hdr.name, "input.txt"); - TEST_ASSERT(!hdr.unknown_record); - TEST_ASSERT(read_retry("data2", fp, buffer, 5) == 0); - buffer[5] = '\0'; - TEST_STR_EQUAL(buffer, "test\n"); - clear_header(&hdr); - fclose(fp); - - fp = test_open_read("file-size/12-digit.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 01750); - TEST_EQUAL_UI(hdr.sb.st_gid, 01750); - TEST_EQUAL_UI(hdr.sb.st_size, 8589934592); - TEST_EQUAL_UI(hdr.sb.st_mtime, 013375730126); - TEST_EQUAL_UI(hdr.mtime, 013375730126); - TEST_STR_EQUAL(hdr.name, "big-file.bin"); - TEST_ASSERT(!hdr.unknown_record); - clear_header(&hdr); - fclose(fp); - - fp = test_open_read("user-group-largenum/8-digit.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 8388608); - TEST_EQUAL_UI(hdr.sb.st_gid, 8388608); - TEST_EQUAL_UI(hdr.sb.st_size, 5); - TEST_EQUAL_UI(hdr.sb.st_mtime, 013376036700); - TEST_EQUAL_UI(hdr.mtime, 013376036700); - TEST_STR_EQUAL(hdr.name, "input.txt"); - TEST_ASSERT(!hdr.unknown_record); - TEST_ASSERT(read_retry("data3", fp, buffer, 5) == 0); - buffer[5] = '\0'; - TEST_STR_EQUAL(buffer, "test\n"); - clear_header(&hdr); - fclose(fp); - - fp = test_open_read("large-mtime/12-digit.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 01750); - TEST_EQUAL_UI(hdr.sb.st_gid, 01750); - TEST_EQUAL_UI(hdr.sb.st_size, 5); - - if (sizeof(time_t) * CHAR_BIT < 64) { - TEST_EQUAL_UI(hdr.sb.st_mtime, INT32_MAX); - } else { - TEST_EQUAL_UI(hdr.sb.st_mtime, 8589934592L); - } - - TEST_EQUAL_UI(hdr.mtime, 8589934592L); - TEST_STR_EQUAL(hdr.name, "input.txt"); - TEST_ASSERT(!hdr.unknown_record); - TEST_ASSERT(read_retry("data4", fp, buffer, 5) == 0); - buffer[5] = '\0'; - TEST_STR_EQUAL(buffer, "test\n"); - clear_header(&hdr); - fclose(fp); - - fp = test_open_read("long-paths/ustar.tar"); - TEST_ASSERT(read_header(fp, &hdr) == 0); - TEST_EQUAL_UI(hdr.sb.st_mode, S_IFREG | 0644); - TEST_EQUAL_UI(hdr.sb.st_uid, 01750); - TEST_EQUAL_UI(hdr.sb.st_gid, 01750); - TEST_EQUAL_UI(hdr.sb.st_size, 5); - TEST_EQUAL_UI(hdr.sb.st_mtime, 1542909670); - TEST_EQUAL_UI(hdr.mtime, 1542909670); - TEST_STR_EQUAL(hdr.name, filename); - TEST_ASSERT(!hdr.unknown_record); - TEST_ASSERT(read_retry("data5", fp, buffer, 5) == 0); - buffer[5] = '\0'; - TEST_STR_EQUAL(buffer, "test\n"); - clear_header(&hdr); - fclose(fp); - + testcase_simple("format-acceptance/ustar.tar", 1542905892, + 1000, 1000, "input.txt"); + testcase_simple("format-acceptance/ustar-pre-posix.tar", 1542905892, + 1000, 1000, "input.txt"); + testcase_simple("format-acceptance/v7.tar", 1542905892, + 1000, 1000, "input.txt"); + testcase_simple("user-group-largenum/8-digit.tar", 1542995392, + 8388608, 8388608, "input.txt"); + testcase_simple("large-mtime/12-digit.tar", 8589934592L, + 1000, 1000, "input.txt"); + testcase_simple("long-paths/ustar.tar", 1542909670, + 1000, 1000, filename); + + test_case_file_size("file-size/12-digit.tar"); return EXIT_SUCCESS; } |