diff options
author | Stef Walter <stef@thewalter.net> | 2013-10-09 21:39:42 +0200 |
---|---|---|
committer | Stef Walter <stef@thewalter.net> | 2014-07-08 08:57:30 +0200 |
commit | 895f0416448c297a3d06160d748cd0e94eadb366 (patch) | |
tree | e4616391553d5c5979d4770baa9c9b8004d8ae6c /common | |
parent | ccc5e1569b360b54962e7f4cfaded8ab466b021d (diff) |
test: Move some file and directory code into general test stuff
Diffstat (limited to 'common')
-rw-r--r-- | common/test.c | 83 | ||||
-rw-r--r-- | common/test.h | 10 |
2 files changed, 93 insertions, 0 deletions
diff --git a/common/test.c b/common/test.c index 83e9644..a006f74 100644 --- a/common/test.c +++ b/common/test.c @@ -42,6 +42,7 @@ #include "path.h" #include <assert.h> +#include <dirent.h> #include <errno.h> #include <setjmp.h> #include <stdarg.h> @@ -339,6 +340,88 @@ p11_test_directory (const char *prefix) return directory; } +void +p11_test_file_write (const char *base, + const char *name, + const void *contents, + size_t length) +{ + char *path = NULL; + FILE *f; + + if (base) { + if (asprintf (&path, "%s/%s", base, name) < 0) + assert_not_reached (); + name = path; + } + + f = fopen (name, "wb"); + if (f == NULL) { + printf ("# couldn't open file for writing: %s: %s\n", name, strerror (errno)); + free (path); + assert_not_reached (); + } + + if (fwrite (contents, 1, length, f) != length || + fclose (f) != 0) { + printf ("# couldn't write to file: %s: %s\n", name, strerror (errno)); + free (path); + assert_not_reached (); + } + + free (path); +} + +void +p11_test_file_delete (const char *base, + const char *name) +{ + char *path = NULL; + + if (base) { + if (asprintf (&path, "%s/%s", base, name) < 0) + assert_not_reached (); + name = path; + } + + if (unlink (name) < 0) { + printf ("# Couldn't delete file: %s\n", name); + free (path); + assert_not_reached (); + } + + free (path); +} + +void +p11_test_directory_delete (const char *directory) +{ + struct dirent *dp; + DIR *dir; + + dir = opendir (directory); + if (dir == NULL) { + printf ("# Couldn't open directory: %s\n", directory); + assert_not_reached (); + } + + while ((dp = readdir (dir)) != NULL) { + if (strcmp (dp->d_name, ".") == 0 || + strcmp (dp->d_name, "..") == 0) + continue; + + p11_test_file_delete (directory, dp->d_name); + } + + closedir (dir); + + if (rmdir (directory) < 0) { + printf ("# Couldn't remove directory: %s\n", directory); + assert_not_reached (); + } +} + + #ifdef OS_UNIX static void diff --git a/common/test.h b/common/test.h index c9f519a..2d9fa69 100644 --- a/common/test.h +++ b/common/test.h @@ -130,6 +130,16 @@ int p11_test_run (int argc, char * p11_test_directory (const char *prefix); +void p11_test_directory_delete (const char *directory); + +void p11_test_file_write (const char *directory, + const char *name, + const void *contents, + size_t length); + +void p11_test_file_delete (const char *directory, + const char *name); + #ifdef OS_UNIX char * p11_test_copy_setgid (const char *path); |