summaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authorStef Walter <stef@thewalter.net>2013-10-09 21:39:42 +0200
committerStef Walter <stef@thewalter.net>2014-07-08 08:57:30 +0200
commit895f0416448c297a3d06160d748cd0e94eadb366 (patch)
treee4616391553d5c5979d4770baa9c9b8004d8ae6c /common
parentccc5e1569b360b54962e7f4cfaded8ab466b021d (diff)
test: Move some file and directory code into general test stuff
Diffstat (limited to 'common')
-rw-r--r--common/test.c83
-rw-r--r--common/test.h10
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);