diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2019-07-04 12:43:57 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2019-07-04 13:42:06 +0200 |
commit | 6623b1fe4df1e2fceb27eff286a86cf36809b2bc (patch) | |
tree | 95dce50157ca3f79e3fdcfae901a124660f20e93 /tests/tar_xattr_schily.c | |
parent | 56c1be44b5f77b067994a6f8f6ef2b397d7acadc (diff) |
libtar: add support for xattr extensions
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'tests/tar_xattr_schily.c')
-rw-r--r-- | tests/tar_xattr_schily.c | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/tests/tar_xattr_schily.c b/tests/tar_xattr_schily.c new file mode 100644 index 0000000..481e6ea --- /dev/null +++ b/tests/tar_xattr_schily.c @@ -0,0 +1,60 @@ +/* SPDX-License-Identifier: GPL-3.0-or-later */ +#include "util.h" +#include "tar.h" + +#include <unistd.h> +#include <assert.h> +#include <stdlib.h> +#include <string.h> +#include <fcntl.h> +#include <stdio.h> + +#define STR(x) #x +#define STRVALUE(x) STR(x) + +#define TEST_PATH STRVALUE(TESTPATH) + +static int open_read(const char *path) +{ + int fd = open(path, O_RDONLY); + + if (fd < 0) { + perror(path); + exit(EXIT_FAILURE); + } + + return fd; +} + +int main(void) +{ + tar_header_decoded_t hdr; + char buffer[6]; + int fd; + + assert(chdir(TEST_PATH) == 0); + + fd = open_read("xattr/xattr-schily.tar"); + assert(read_header(fd, &hdr) == 0); + assert(hdr.sb.st_mode == (S_IFREG | 0644)); + assert(hdr.sb.st_uid == 01750); + assert(hdr.sb.st_gid == 01750); + assert(hdr.sb.st_size == 5); + assert(hdr.sb.st_mtime == 1543094477); + assert(hdr.sb.st_atime == 1543094642); + assert(hdr.sb.st_ctime == 1543094606); + assert(strcmp(hdr.name, "input.txt") == 0); + assert(!hdr.unknown_record); + assert(read_retry(fd, buffer, 5) == 5); + buffer[5] = '\0'; + assert(strcmp(buffer, "test\n") == 0); + + assert(hdr.xattr != NULL); + assert(strcmp(hdr.xattr->key, "user.mime_type") == 0); + assert(strcmp(hdr.xattr->value, "text/plain") == 0); + assert(hdr.xattr->next == NULL); + + clear_header(&hdr); + close(fd); + return EXIT_SUCCESS; +} |