[libgsystem] tests: Add more shutil tests
- From: Colin Walters <walters src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libgsystem] tests: Add more shutil tests
- Date: Wed, 17 Dec 2014 22:51:46 +0000 (UTC)
commit 4a688388ffea81bed22c71472ad91152fe3475a9
Author: Colin Walters <walters verbum org>
Date: Wed Dec 17 17:51:31 2014 -0500
tests: Add more shutil tests
tests/shutil.c | 125 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 125 insertions(+), 0 deletions(-)
---
diff --git a/tests/shutil.c b/tests/shutil.c
index 6461ede..1de644f 100644
--- a/tests/shutil.c
+++ b/tests/shutil.c
@@ -3,6 +3,7 @@
#include <string.h>
#include <libgsystem.h>
+#include <glib-unix.h>
static void
test_shutil_rm_rf_noent (void)
@@ -14,6 +15,127 @@ test_shutil_rm_rf_noent (void)
g_assert_no_error (error);
}
+static void
+test_shutil_rm_rf_file (void)
+{
+ GError *error = NULL;
+ GFile *empty = g_file_new_for_path ("empty");
+
+ (void) g_file_replace_contents (empty, "", 0, NULL, FALSE, 0, NULL, NULL, &error);
+ g_assert_no_error (error);
+
+ g_assert (g_file_query_exists (empty, NULL));
+
+ (void) gs_shutil_rm_rf (empty, NULL, &error);
+ g_assert_no_error (error);
+
+ g_assert (!g_file_query_exists (empty, NULL));
+}
+
+static void
+test_shutil_rm_rf_dir (void)
+{
+ GError *error = NULL;
+ GFile *empty = g_file_new_for_path ("empty");
+
+ (void) g_file_make_directory (empty, NULL, &error);
+ g_assert_no_error (error);
+
+ g_assert (g_file_query_exists (empty, NULL));
+
+ (void) gs_shutil_rm_rf (empty, NULL, &error);
+ g_assert_no_error (error);
+
+ g_assert (!g_file_query_exists (empty, NULL));
+}
+
+static void
+test_shutil_rm_rf_random (void)
+{
+ GError *error = NULL;
+ GFile *testdir = g_file_new_for_path ("testdir");
+ guint i = 0, depth = 0;
+ const guint maxdepth = 20;
+ DIR *cwddir = NULL;
+ int r;
+
+ (void) g_file_make_directory (testdir, NULL, &error);
+ g_assert_no_error (error);
+
+ cwddir = opendir ("testdir");
+
+ for (i = 0; i < 255; i++)
+ {
+ guint8 op = (guint8)g_random_int_range (0, 5);
+ gs_free char *name = NULL;
+
+ name = g_strdup_printf ("%02X", g_random_int_range (0, G_MAXUINT8));
+ again:
+ switch (op)
+ {
+ case 0:
+ r = mkdirat (dirfd (cwddir), name, 0755);
+ if (r != 0)
+ continue;
+ break;
+ case 1:
+ if (depth < maxdepth)
+ {
+ int newfd;
+ r = mkdirat (dirfd (cwddir), name, 0755);
+ if (r != 0)
+ continue;
+
+ (void) gs_file_open_dir_fd_at (dirfd (cwddir), name, &newfd, NULL, &error);
+ g_assert_no_error (error);
+
+ (void) closedir (cwddir);
+ depth++;
+ cwddir = fdopendir (newfd);
+ }
+ else
+ {
+ op = 2;
+ goto again;
+ }
+ break;
+ case 2:
+ if (depth > 0)
+ {
+ DIR *newdir = opendir ("..");
+ (void) closedir (cwddir);
+ cwddir = newdir;
+ depth--;
+ }
+ else
+ {
+ op = 1;
+ goto again;
+ }
+ break;
+ case 3:
+ {
+ int fd = openat (dirfd (cwddir), name, O_CREAT | O_CLOEXEC | O_NOFOLLOW, 0644);
+ if (fd != -1)
+ (void) close (fd);
+ }
+ break;
+ case 4:
+ {
+ (void) symlinkat ("notarget", dirfd (cwddir), name);
+ }
+ }
+ }
+
+ (void) closedir (cwddir);
+
+ system ("ls -lR testdir");
+
+ (void) gs_shutil_rm_rf (testdir, NULL, &error);
+
+ g_assert (!g_file_query_exists (testdir, NULL));
+}
+
int
main (int argc,
char *argv[])
@@ -21,6 +143,9 @@ main (int argc,
g_test_init (&argc, &argv, NULL);
g_test_add_func ("/shutil/rmrf-noent", test_shutil_rm_rf_noent);
+ g_test_add_func ("/shutil/rmrf-file", test_shutil_rm_rf_file);
+ g_test_add_func ("/shutil/rmrf-dir", test_shutil_rm_rf_file);
+ g_test_add_func ("/shutil/rmrf-random", test_shutil_rm_rf_random);
return g_test_run ();
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]