[glib] Move bookmarkfile tests to the test framework



commit e4b5104003e9281e5737a9611517c4878522df5c
Author: Matthias Clasen <mclasen redhat com>
Date:   Sun Aug 1 02:07:21 2010 -0400

    Move bookmarkfile tests to the test framework

 glib/tests/Makefile.am                        |    7 +
 glib/tests/bookmarkfile.c                     |  298 +++++++++++++++++++++++++
 {tests => glib/tests}/bookmarks/fail-01.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-02.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-03.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-04.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-05.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-06.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-07.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-08.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-09.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-10.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-11.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-12.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-13.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-14.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-15.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-16.xbel  |    0
 {tests => glib/tests}/bookmarks/fail-17.xbel  |    0
 {tests => glib/tests}/bookmarks/valid-01.xbel |    0
 {tests => glib/tests}/bookmarks/valid-02.xbel |    0
 {tests => glib/tests}/bookmarks/valid-03.xbel |    0
 tests/Makefile.am                             |    8 +-
 tests/bookmarkfile-test.c                     |  188 ----------------
 tests/run-bookmark-test.sh                    |   34 ---
 25 files changed, 307 insertions(+), 228 deletions(-)
---
diff --git a/glib/tests/Makefile.am b/glib/tests/Makefile.am
index 81a3cec..0a137b0 100644
--- a/glib/tests/Makefile.am
+++ b/glib/tests/Makefile.am
@@ -143,6 +143,9 @@ logging_LDADD       = $(progs_ldadd)
 TEST_PROGS         += error
 error_LDADD         = $(progs_ldadd)
 
+TEST_PROGS         += bookmarkfile
+bookmarkfile_LDADD  = $(progs_ldadd)
+
 if OS_UNIX
 
 # some testing of gtester funcitonality
@@ -166,3 +169,7 @@ dist_hook:
 	mkdir $(distdir)/markups;		\
 	for f in $(srcdir)/markups/*; do 	\
 	  cp $$f $(distdir)/markups; done
+	mkdir $(distdir)/bookmarks;		\
+	for f in $(srcdir)/bookmarks/* ; do 	\
+	  cp $$f $(distdir)/bookmarks; done
+
diff --git a/glib/tests/bookmarkfile.c b/glib/tests/bookmarkfile.c
new file mode 100644
index 0000000..5e1eac7
--- /dev/null
+++ b/glib/tests/bookmarkfile.c
@@ -0,0 +1,298 @@
+#undef G_DISABLE_ASSERT
+
+#include <glib.h>
+#include <time.h>
+#include <locale.h>
+#include <string.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+#ifndef SRCDIR
+#define SRCDIR "."
+#endif
+
+#define TEST_URI_0 	"file:///abc/defgh/ijklmnopqrstuvwxyz"
+#define TEST_URI_1 	"file:///test/uri/1"
+#define TEST_URI_2 	"file:///test/uri/2"
+
+#define TEST_MIME 	"text/plain"
+
+#define TEST_APP_NAME 	"bookmarkfile-test"
+#define TEST_APP_EXEC 	"bookmarkfile-test %f"
+
+static gboolean
+test_load (GBookmarkFile *bookmark,
+           const gchar   *filename)
+{
+  GError *error = NULL;
+  gboolean res;
+  
+  res = g_bookmark_file_load_from_file (bookmark, filename, &error);
+  if (error && g_test_verbose ())
+    {
+      g_print ("Load error: %s\n", error->message);
+      g_error_free (error);
+    }
+
+  return res;
+}
+
+static void
+test_query (GBookmarkFile *bookmark)
+{
+  gint size;
+  gchar **uris;
+  gsize uris_len, i;
+  gchar *mime;
+  GError *error;
+
+  size = g_bookmark_file_get_size (bookmark);
+  uris = g_bookmark_file_get_uris (bookmark, &uris_len);
+
+  g_assert_cmpint (uris_len, ==, size);
+
+  for (i = 0; i < uris_len; i++)
+    {
+      g_assert (g_bookmark_file_has_item (bookmark, uris[i]));
+      error = NULL;
+      mime = g_bookmark_file_get_mime_type (bookmark, uris[i], &error);
+      g_assert (mime != NULL);
+      g_assert_no_error (error);
+      g_free (mime);
+    }
+  g_strfreev (uris);
+
+  g_assert (!g_bookmark_file_has_item (bookmark, "file:///no/such/uri"));
+  error = NULL;
+  mime = g_bookmark_file_get_mime_type (bookmark, "file:///no/such/uri", &error);
+  g_assert (mime == NULL);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_error_free (error);
+  g_free (mime);
+}
+
+static gboolean
+test_modify (GBookmarkFile *bookmark)
+{
+  gchar *text;
+  guint count;
+  time_t stamp;
+  time_t now;
+  GError *error = NULL;
+  gchar **groups;
+  gsize length;
+  gchar **apps;
+  gchar *icon;
+  gchar *mime;
+
+  if (g_test_verbose ())
+    g_print ("\t=> check global title/description...");
+  g_bookmark_file_set_title (bookmark, NULL, "a file");
+  g_bookmark_file_set_description (bookmark, NULL, "a bookmark file");
+
+  text = g_bookmark_file_get_title (bookmark, NULL, &error);
+  g_assert_no_error (error);
+  g_assert_cmpstr (text, ==, "a file");
+  g_free (text);
+
+  text = g_bookmark_file_get_description (bookmark, NULL, &error);
+  g_assert_no_error (error);
+  g_assert_cmpstr (text, ==, "a bookmark file");
+  g_free (text);
+  if (g_test_verbose ())
+    g_print ("ok\n");
+
+  if (g_test_verbose ())
+    g_print ("\t=> check bookmark title/description...");
+  g_bookmark_file_set_title (bookmark, TEST_URI_0, "a title");
+  g_bookmark_file_set_description (bookmark, TEST_URI_0, "a description");
+  g_bookmark_file_set_is_private (bookmark, TEST_URI_0, TRUE);
+  time (&now);
+  g_bookmark_file_set_added (bookmark, TEST_URI_0, now);
+  g_bookmark_file_set_modified (bookmark, TEST_URI_0, now);
+  g_bookmark_file_set_visited (bookmark, TEST_URI_0, now);
+  g_bookmark_file_set_icon (bookmark, TEST_URI_0, "testicon", "image/png");
+
+  text = g_bookmark_file_get_title (bookmark, TEST_URI_0, &error);
+  g_assert_no_error (error);
+  g_assert_cmpstr (text, ==, "a title");
+  g_free (text);
+  text = g_bookmark_file_get_description (bookmark, TEST_URI_0, &error);
+  g_assert_no_error (error);
+  g_assert_cmpstr (text, ==, "a description");
+  g_free (text);
+  g_assert (g_bookmark_file_get_is_private (bookmark, TEST_URI_0, &error));
+  g_assert_no_error (error);
+  stamp = g_bookmark_file_get_added (bookmark, TEST_URI_0, &error);
+  g_assert_no_error (error);
+  g_assert (stamp == now);
+  stamp = g_bookmark_file_get_modified (bookmark, TEST_URI_0, &error);
+  g_assert_no_error (error);
+  g_assert (stamp == now);
+  stamp = g_bookmark_file_get_visited (bookmark, TEST_URI_0, &error);
+  g_assert_no_error (error);
+  g_assert (stamp == now);
+  g_assert (g_bookmark_file_get_icon (bookmark, TEST_URI_0, &icon, &mime, &error));
+  g_assert_no_error (error);
+  g_assert_cmpstr (icon, ==, "testicon");
+  g_assert_cmpstr (mime, ==, "image/png");
+  g_free (icon);
+  g_free (mime);
+  if (g_test_verbose ())
+    g_print ("ok\n");
+
+  if (g_test_verbose ())
+    g_print ("\t=> check non existing bookmark...");
+  g_bookmark_file_get_description (bookmark, TEST_URI_1, &error);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_clear_error (&error);
+  g_bookmark_file_get_is_private (bookmark, TEST_URI_1, &error);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_clear_error (&error);
+  g_bookmark_file_get_added (bookmark, TEST_URI_1, &error);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_clear_error (&error);
+  g_bookmark_file_get_modified (bookmark, TEST_URI_1, &error);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_clear_error (&error);
+  g_bookmark_file_get_visited (bookmark, TEST_URI_1, &error);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_clear_error (&error);
+  if (g_test_verbose ())
+    g_print ("ok\n");
+
+  if (g_test_verbose ())
+    g_print ("\t=> check application...");
+  g_bookmark_file_set_mime_type (bookmark, TEST_URI_0, TEST_MIME);
+  g_assert (!g_bookmark_file_has_application (bookmark, TEST_URI_0, TEST_APP_NAME, NULL));
+  g_bookmark_file_add_application (bookmark, TEST_URI_0,
+				   TEST_APP_NAME,
+				   TEST_APP_EXEC);
+  g_assert (g_bookmark_file_has_application (bookmark, TEST_URI_0, TEST_APP_NAME, NULL));
+  g_bookmark_file_get_app_info (bookmark, TEST_URI_0, TEST_APP_NAME,
+		  		&text,
+				&count,
+				&stamp,
+				&error);
+  g_assert_no_error (error);
+  g_assert (count == 1);
+  g_assert (stamp == g_bookmark_file_get_modified (bookmark, TEST_URI_0, NULL));
+  g_free (text);
+  g_assert (g_bookmark_file_remove_application (bookmark, TEST_URI_0, TEST_APP_NAME, &error));
+  g_assert_no_error (error);
+  g_bookmark_file_add_application (bookmark, TEST_URI_0, TEST_APP_NAME, TEST_APP_EXEC);
+  apps = g_bookmark_file_get_applications (bookmark, TEST_URI_0, &length, &error);
+  g_assert_no_error (error);
+  g_assert_cmpint (length, ==, 1);
+  g_assert_cmpstr (apps[0], ==, TEST_APP_NAME);
+  g_strfreev (apps);
+
+  g_bookmark_file_get_app_info (bookmark, TEST_URI_0, "fail",
+		  		&text,
+				&count,
+				&stamp,
+				&error);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED);
+  g_clear_error (&error);
+
+  if (g_test_verbose ())
+    g_print ("ok\n"); 
+
+  if (g_test_verbose ())
+    g_print ("\t=> check groups...");
+  g_assert (!g_bookmark_file_has_group (bookmark, TEST_URI_1, "Test", NULL));
+  g_bookmark_file_add_group (bookmark, TEST_URI_1, "Test");
+  g_assert (g_bookmark_file_has_group (bookmark, TEST_URI_1, "Test", NULL));
+  g_assert (!g_bookmark_file_has_group (bookmark, TEST_URI_1, "Fail", NULL));
+  g_assert (g_bookmark_file_remove_group (bookmark, TEST_URI_1, "Test", &error));
+  g_assert_no_error (error);
+  groups = g_bookmark_file_get_groups (bookmark, TEST_URI_1, NULL, &error);
+  g_assert_cmpint (g_strv_length (groups), ==, 0);
+  g_strfreev (groups);
+  groups = g_new0 (gchar *, 3);
+  groups[0] = "Group1";
+  groups[1] = "Group2";
+  groups[2] = NULL;
+  g_bookmark_file_set_groups (bookmark, TEST_URI_1, (const gchar **)groups, 2);
+  g_free (groups);
+  groups = g_bookmark_file_get_groups (bookmark, TEST_URI_1, &length, &error);
+  g_assert_cmpint (length, ==, 2);
+  g_strfreev (groups);
+  g_assert_no_error (error);
+
+  if (g_test_verbose ())
+    g_print ("ok\n");
+
+  if (g_test_verbose ())
+    g_print ("\t=> check remove...");
+  g_assert (g_bookmark_file_remove_item (bookmark, TEST_URI_1, &error) == TRUE);
+  g_assert_no_error (error);
+  g_assert (g_bookmark_file_remove_item (bookmark, TEST_URI_1, &error) == FALSE);
+  g_assert_error (error, G_BOOKMARK_FILE_ERROR, G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND);
+  g_clear_error (&error);
+  if (g_test_verbose ())
+    g_print ("ok\n");
+  
+  return TRUE;
+}
+
+static void
+test_file (gconstpointer d)
+{
+  const gchar *filename = d;
+  GBookmarkFile *bookmark_file;
+  gboolean success;
+  gchar *data;
+  GError *error;
+
+  bookmark_file = g_bookmark_file_new ();
+  g_assert (bookmark_file != NULL);
+
+  success = test_load (bookmark_file, filename);
+
+  if (success)
+    {
+      test_query (bookmark_file);
+      test_modify (bookmark_file);
+
+      error = NULL;
+      data = g_bookmark_file_to_data (bookmark_file, NULL, &error);
+      g_assert_no_error (error);
+      /* FIXME do some checks on data */
+      g_free (data);
+    }
+
+  g_bookmark_file_free (bookmark_file);
+
+  g_assert (success == (strstr (filename, "fail") == NULL));
+}
+
+int
+main (int argc, char *argv[])
+{
+  GDir *dir;
+  GError *error;
+  const gchar *name;
+  gchar *path;
+
+  g_test_init (&argc, &argv, NULL);
+
+  if (argc > 1)
+    {
+      test_file (argv[1]);
+      return 0;
+    }
+
+  error = NULL;
+  dir = g_dir_open (SRCDIR "/bookmarks", 0, &error);
+  g_assert_no_error (error);
+  while ((name = g_dir_read_name (dir)) != NULL)
+    {
+      path = g_strdup_printf ("/bookmarks/parse/%s", name);
+      g_test_add_data_func (path, g_build_filename (SRCDIR, "bookmarks", name, NULL), test_file);
+      g_free (path);
+    }
+  g_dir_close (dir);
+
+  return g_test_run ();
+}
diff --git a/tests/bookmarks/fail-01.xbel b/glib/tests/bookmarks/fail-01.xbel
similarity index 100%
rename from tests/bookmarks/fail-01.xbel
rename to glib/tests/bookmarks/fail-01.xbel
diff --git a/tests/bookmarks/fail-02.xbel b/glib/tests/bookmarks/fail-02.xbel
similarity index 100%
rename from tests/bookmarks/fail-02.xbel
rename to glib/tests/bookmarks/fail-02.xbel
diff --git a/tests/bookmarks/fail-03.xbel b/glib/tests/bookmarks/fail-03.xbel
similarity index 100%
rename from tests/bookmarks/fail-03.xbel
rename to glib/tests/bookmarks/fail-03.xbel
diff --git a/tests/bookmarks/fail-04.xbel b/glib/tests/bookmarks/fail-04.xbel
similarity index 100%
rename from tests/bookmarks/fail-04.xbel
rename to glib/tests/bookmarks/fail-04.xbel
diff --git a/tests/bookmarks/fail-05.xbel b/glib/tests/bookmarks/fail-05.xbel
similarity index 100%
rename from tests/bookmarks/fail-05.xbel
rename to glib/tests/bookmarks/fail-05.xbel
diff --git a/tests/bookmarks/fail-06.xbel b/glib/tests/bookmarks/fail-06.xbel
similarity index 100%
rename from tests/bookmarks/fail-06.xbel
rename to glib/tests/bookmarks/fail-06.xbel
diff --git a/tests/bookmarks/fail-07.xbel b/glib/tests/bookmarks/fail-07.xbel
similarity index 100%
rename from tests/bookmarks/fail-07.xbel
rename to glib/tests/bookmarks/fail-07.xbel
diff --git a/tests/bookmarks/fail-08.xbel b/glib/tests/bookmarks/fail-08.xbel
similarity index 100%
rename from tests/bookmarks/fail-08.xbel
rename to glib/tests/bookmarks/fail-08.xbel
diff --git a/tests/bookmarks/fail-09.xbel b/glib/tests/bookmarks/fail-09.xbel
similarity index 100%
rename from tests/bookmarks/fail-09.xbel
rename to glib/tests/bookmarks/fail-09.xbel
diff --git a/tests/bookmarks/fail-10.xbel b/glib/tests/bookmarks/fail-10.xbel
similarity index 100%
rename from tests/bookmarks/fail-10.xbel
rename to glib/tests/bookmarks/fail-10.xbel
diff --git a/tests/bookmarks/fail-11.xbel b/glib/tests/bookmarks/fail-11.xbel
similarity index 100%
rename from tests/bookmarks/fail-11.xbel
rename to glib/tests/bookmarks/fail-11.xbel
diff --git a/tests/bookmarks/fail-12.xbel b/glib/tests/bookmarks/fail-12.xbel
similarity index 100%
rename from tests/bookmarks/fail-12.xbel
rename to glib/tests/bookmarks/fail-12.xbel
diff --git a/tests/bookmarks/fail-13.xbel b/glib/tests/bookmarks/fail-13.xbel
similarity index 100%
rename from tests/bookmarks/fail-13.xbel
rename to glib/tests/bookmarks/fail-13.xbel
diff --git a/tests/bookmarks/fail-14.xbel b/glib/tests/bookmarks/fail-14.xbel
similarity index 100%
rename from tests/bookmarks/fail-14.xbel
rename to glib/tests/bookmarks/fail-14.xbel
diff --git a/tests/bookmarks/fail-15.xbel b/glib/tests/bookmarks/fail-15.xbel
similarity index 100%
rename from tests/bookmarks/fail-15.xbel
rename to glib/tests/bookmarks/fail-15.xbel
diff --git a/tests/bookmarks/fail-16.xbel b/glib/tests/bookmarks/fail-16.xbel
similarity index 100%
rename from tests/bookmarks/fail-16.xbel
rename to glib/tests/bookmarks/fail-16.xbel
diff --git a/tests/bookmarks/fail-17.xbel b/glib/tests/bookmarks/fail-17.xbel
similarity index 100%
rename from tests/bookmarks/fail-17.xbel
rename to glib/tests/bookmarks/fail-17.xbel
diff --git a/tests/bookmarks/valid-01.xbel b/glib/tests/bookmarks/valid-01.xbel
similarity index 100%
rename from tests/bookmarks/valid-01.xbel
rename to glib/tests/bookmarks/valid-01.xbel
diff --git a/tests/bookmarks/valid-02.xbel b/glib/tests/bookmarks/valid-02.xbel
similarity index 100%
rename from tests/bookmarks/valid-02.xbel
rename to glib/tests/bookmarks/valid-02.xbel
diff --git a/tests/bookmarks/valid-03.xbel b/glib/tests/bookmarks/valid-03.xbel
similarity index 100%
rename from tests/bookmarks/valid-03.xbel
rename to glib/tests/bookmarks/valid-03.xbel
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 6d5c102..5eed30a 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -112,9 +112,9 @@ test_programs =					\
 	unicode-caseconv			\
 	unicode-encoding
 
-test_scripts = run-collate-tests.sh run-bookmark-test.sh run-assert-msg-test.sh
+test_scripts = run-collate-tests.sh run-assert-msg-test.sh
 
-test_script_support_programs = unicode-collate bookmarkfile-test
+test_script_support_programs = unicode-collate
 
 check_PROGRAMS = $(test_programs) $(test_script_support_programs)
 
@@ -130,7 +130,6 @@ module_ldadd = $(libgmodule) $(G_MODULE_LIBS) $(progs_ldadd)
 
 atomic_test_LDADD = $(progs_ldadd)
 bit_test_LDADD = $(progs_ldadd)
-bookmarkfile_test_LDADD = $(progs_ldadd)
 child_test_LDADD = $(thread_ldadd)
 completion_test_LDADD = $(progs_ldadd)
 date_test_LDADD = $(progs_ldadd)
@@ -182,9 +181,6 @@ dist-hook: $(BUILT_EXTRA_DIST)
 	mkdir $(distdir)/collate;          			\
 	for f in $(srcdir)/collate/* ; do  			\
           if test -f $$f; then cp $$f $(distdir)/collate; fi; done
-	mkdir $(distdir)/bookmarks;          			\
-	for f in $(srcdir)/bookmarks/* ; do  			\
-	  cp $$f $(distdir)/bookmarks; done 
 
 DISTCLEANFILES =		\
 	iochannel-test-outfile 	\



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]