summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2005-02-01 14:10:46 +0000
committerMatthias Clasen <matthiasc@src.gnome.org>2005-02-01 14:10:46 +0000
commitdf59e8e19bf605d5c8b05cd78217b879efce08a7 (patch)
tree9907dc78f7ea7729c4e879eec0cf555b10313622 /tests
parent0e93338bc006ca1fb472e74ed494230578e1ed30 (diff)
Add test case for group removal.
2005-02-01 Matthias Clasen <mclasen@redhat.com> * tests/keyfile-test.c (test_group_remove): Add test case for group removal. * glib/gkeyfile.c (g_key_file_remove_group): Don't segfault if the group doesn't exist. (#165887, Mathias Hasselmann)
Diffstat (limited to 'tests')
-rw-r--r--tests/keyfile-test.c70
1 files changed, 70 insertions, 0 deletions
diff --git a/tests/keyfile-test.c b/tests/keyfile-test.c
index 0e86af992..62e4e2243 100644
--- a/tests/keyfile-test.c
+++ b/tests/keyfile-test.c
@@ -519,6 +519,8 @@ test_boolean (void)
g_key_file_get_boolean (keyfile, "invalid", "key4", &error);
check_error (&error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_INVALID_VALUE);
+
+ g_key_file_free (keyfile);
}
/* check parsing of integer values */
@@ -562,6 +564,73 @@ test_integer (void)
g_key_file_get_integer (keyfile, "invalid", "key4", &error);
check_error (&error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_INVALID_VALUE);
+
+ g_key_file_free (keyfile);
+}
+
+/* http://bugzilla.gnome.org/show_bug.cgi?id=165887 */
+static void
+test_group_remove (void)
+{
+ GKeyFile *keyfile;
+ gchar **names;
+ gsize len;
+ GError *error = NULL;
+
+ const gchar *data =
+ "[group1]\n"
+ "[group2]\n"
+ "key1=bla\n"
+ "key2=bla\n"
+ "[group3]\n"
+ "key1=bla\n"
+ "key2=bla\n";
+
+ keyfile = load_data (data, 0);
+
+ names = g_key_file_get_groups (keyfile, &len);
+ if (names == NULL)
+ {
+ g_print ("Error listing groups\n");
+ exit (1);
+ }
+
+ check_length ("groups", g_strv_length (names), len, 3);
+ check_name ("group name", names[0], "group1", 0);
+ check_name ("group name", names[1], "group2", 1);
+ check_name ("group name", names[2], "group3", 2);
+
+ g_key_file_remove_group (keyfile, "group1", &error);
+ check_no_error (&error);
+
+ names = g_key_file_get_groups (keyfile, &len);
+ if (names == NULL)
+ {
+ g_print ("Error listing groups\n");
+ exit (1);
+ }
+
+ check_length ("groups", g_strv_length (names), len, 2);
+ check_name ("group name", names[0], "group2", 0);
+ check_name ("group name", names[1], "group3", 1);
+
+ g_key_file_remove_group (keyfile, "group2", &error);
+ check_no_error (&error);
+
+ names = g_key_file_get_groups (keyfile, &len);
+ if (names == NULL)
+ {
+ g_print ("Error listing groups\n");
+ exit (1);
+ }
+
+ check_length ("groups", g_strv_length (names), len, 1);
+ check_name ("group name", names[0], "group3", 0);
+
+ g_key_file_remove_group (keyfile, "no such group", &error);
+ check_error (&error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_GROUP_NOT_FOUND);
+
+ g_key_file_free (keyfile);
}
/* check handling of translated strings */
@@ -680,6 +749,7 @@ main (int argc, char *argv[])
test_integer ();
test_locale_string ();
test_lists ();
+ test_group_remove ();
return 0;
}