test_basic (void)
{
gchar *str = NULL;
+ GObject *b;
+ gchar *path;
+ gboolean has_unapplied;
+ gboolean delay_apply;
GSettings *settings;
settings = g_settings_new ("org.gtk.test");
- g_object_get (settings, "schema", &str, NULL);
+ g_object_get (settings,
+ "schema-id", &str,
+ "backend", &b,
+ "path", &path,
+ "has-unapplied", &has_unapplied,
+ "delay-apply", &delay_apply,
+ NULL);
g_assert_cmpstr (str, ==, "org.gtk.test");
+ g_assert (b != NULL);
+ g_assert_cmpstr (path, ==, "/tests/");
+ g_assert (!has_unapplied);
+ g_assert (!delay_apply);
g_free (str);
+ g_object_unref (b);
+ g_free (path);
g_settings_get (settings, "greeting", "s", &str);
g_assert_cmpstr (str, ==, "Hello, earthlings");
* that is not in the schema
*/
static void
-test_unknown_key_subprocess (void)
-{
- GSettings *settings;
- GVariant *value;
-
- settings = g_settings_new ("org.gtk.test");
- value = g_settings_get_value (settings, "no_such_key");
-
- g_assert (value == NULL);
-
- g_object_unref (settings);
-}
-
-static void
test_unknown_key (void)
{
if (!g_test_undefined ())
return;
- g_test_trap_subprocess ("/gsettings/unknown-key/subprocess", 0, 0);
+ if (g_test_subprocess ())
+ {
+ GSettings *settings;
+ GVariant *value;
+
+ settings = g_settings_new ("org.gtk.test");
+ value = g_settings_get_value (settings, "no_such_key");
+
+ g_assert (value == NULL);
+
+ g_object_unref (settings);
+ return;
+ }
+ g_test_trap_subprocess (NULL, 0, 0);
g_test_trap_assert_failed ();
g_test_trap_assert_stderr ("*does not contain*");
}
* has not been installed
*/
static void
-test_no_schema_subprocess (void)
-{
- GSettings *settings;
-
- settings = g_settings_new ("no.such.schema");
-
- g_assert (settings == NULL);
-}
-
-static void
test_no_schema (void)
{
if (!g_test_undefined ())
return;
- g_test_trap_subprocess ("/gsettings/no-schema/subprocess", 0, 0);
+ if (g_test_subprocess ())
+ {
+ GSettings *settings;
+
+ settings = g_settings_new ("no.such.schema");
+
+ g_assert (settings == NULL);
+ return;
+ }
+ g_test_trap_subprocess (NULL, 0, 0);
g_test_trap_assert_failed ();
g_test_trap_assert_stderr ("*Settings schema 'no.such.schema' is not installed*");
}
/* Check errors with explicit paths */
static void
-test_wrong_path_subprocess (void)
-{
- GSettings *settings G_GNUC_UNUSED;
-
- settings = g_settings_new_with_path ("org.gtk.test", "/wrong-path/");
-}
-
-static void
test_wrong_path (void)
{
if (!g_test_undefined ())
return;
- g_test_trap_subprocess ("/gsettings/wrong-path/subprocess", 0, 0);
+ if (g_test_subprocess ())
+ {
+ GSettings *settings G_GNUC_UNUSED;
+
+ settings = g_settings_new_with_path ("org.gtk.test", "/wrong-path/");
+ return;
+ }
+ g_test_trap_subprocess (NULL, 0, 0);
g_test_trap_assert_failed ();
g_test_trap_assert_stderr ("*but path * specified by schema*");
}
static void
-test_no_path_subprocess (void)
-{
- GSettings *settings G_GNUC_UNUSED;
-
- settings = g_settings_new ("org.gtk.test.no-path");
-}
-
-static void
test_no_path (void)
{
if (!g_test_undefined ())
return;
- g_test_trap_subprocess ("/gsettings/no-path/subprocess", 0, 0);
+ if (g_test_subprocess ())
+ {
+ GSettings *settings G_GNUC_UNUSED;
+
+ settings = g_settings_new ("org.gtk.test.no-path");
+ return;
+ }
+ g_test_trap_subprocess (NULL, 0, 0);
g_test_trap_assert_failed ();
g_test_trap_assert_stderr ("*attempting to create schema * without a path**");
}
GSettings *settings2;
gchar *str;
gboolean writable;
+ GVariant *v;
+ const gchar *s;
settings = g_settings_new ("org.gtk.test");
settings2 = g_settings_new ("org.gtk.test");
g_free (str);
str = NULL;
+ v = g_settings_get_user_value (settings, "greeting");
+ s = g_variant_get_string (v, NULL);
+ g_assert_cmpstr (s, ==, "greetings from test_delay_apply");
+ g_variant_unref (v);
+
g_settings_get (settings2, "greeting", "s", &str);
g_assert_cmpstr (str, ==, "top o' the morning");
g_free (str);
}
static void
+test_delay_child (void)
+{
+ GSettings *base;
+ GSettings *settings;
+ GSettings *child;
+ guint8 byte;
+ gboolean delay;
+
+ base = g_settings_new ("org.gtk.test.basic-types");
+ g_settings_set (base, "test-byte", "y", 36);
+
+ settings = g_settings_new ("org.gtk.test");
+ g_settings_delay (settings);
+ g_object_get (settings, "delay-apply", &delay, NULL);
+ g_assert (delay);
+
+ child = g_settings_get_child (settings, "basic-types");
+ g_assert (child != NULL);
+
+ g_object_get (child, "delay-apply", &delay, NULL);
+ g_assert (!delay);
+
+ g_settings_get (child, "test-byte", "y", &byte);
+ g_assert_cmpuint (byte, ==, 36);
+
+ g_settings_set (child, "test-byte", "y", 42);
+
+ /* make sure the child was delayed too */
+ g_settings_get (base, "test-byte", "y", &byte);
+ g_assert_cmpuint (byte, ==, 36);
+
+ g_object_unref (child);
+ g_object_unref (settings);
+ g_object_unref (base);
+}
+
+static void
keys_changed_cb (GSettings *settings,
const GQuark *keys,
gint n_keys)
g_assert_cmpstr (s, ==, "decaffeinate,unleaded,keep all surfaces clean");
g_strfreev (strv);
g_free (s);
+ g_settings_set_strv (settings, "strv", NULL);
+ g_object_get (obj, "strv", &strv, NULL);
+ g_assert (strv != NULL);
+ g_assert_cmpint (g_strv_length (strv), ==, 0);
+ g_strfreev (strv);
g_settings_bind (settings, "enum", obj, "enum", G_SETTINGS_BIND_DEFAULT);
g_object_set (obj, "enum", TEST_ENUM_BAZ, NULL);
g_object_unref (settings);
}
-/* Test that type mismatch is caught when creating a binding
- */
-static void
-test_typesafe_binding_subprocess (void)
-{
- TestObject *obj;
- GSettings *settings;
-
- settings = g_settings_new ("org.gtk.test.binding");
- obj = test_object_new ();
-
- g_settings_bind (settings, "string", obj, "int", G_SETTINGS_BIND_DEFAULT);
-
- g_object_unref (obj);
- g_object_unref (settings);
-}
-
+/* Test that type mismatch is caught when creating a binding */
static void
test_typesafe_binding (void)
{
if (!g_test_undefined ())
return;
- g_test_trap_subprocess ("/gsettings/typesafe-binding/subprocess", 0, 0);
+ if (g_test_subprocess ())
+ {
+ TestObject *obj;
+ GSettings *settings;
+
+ settings = g_settings_new ("org.gtk.test.binding");
+ obj = test_object_new ();
+
+ g_settings_bind (settings, "string", obj, "int", G_SETTINGS_BIND_DEFAULT);
+
+ g_object_unref (obj);
+ g_object_unref (settings);
+ return;
+ }
+ g_test_trap_subprocess (NULL, 0, 0);
g_test_trap_assert_failed ();
g_test_trap_assert_stderr ("*not compatible*");
}
gsize len;
gboolean called = FALSE;
- g_remove ("gsettings.store");
+ g_remove ("keyfile/gsettings.store");
+ g_rmdir ("keyfile");
- kf_backend = g_keyfile_settings_backend_new ("gsettings.store", "/", "root");
+ kf_backend = g_keyfile_settings_backend_new ("keyfile/gsettings.store", "/", "root");
settings = g_settings_new_with_backend ("org.gtk.test", kf_backend);
g_object_unref (kf_backend);
g_settings_apply (settings);
keyfile = g_key_file_new ();
- g_assert (g_key_file_load_from_file (keyfile, "gsettings.store", 0, NULL));
+ g_assert (g_key_file_load_from_file (keyfile, "keyfile/gsettings.store", 0, NULL));
str = g_key_file_get_string (keyfile, "tests", "greeting", NULL);
g_assert_cmpstr (str, ==, "'see if this works'");
str = g_key_file_get_string (keyfile, "tests", "farewell", NULL);
g_assert_cmpstr (str, ==, "'cheerio'");
g_free (str);
+ g_key_file_free (keyfile);
+ g_settings_reset (settings, "greeting");
+ g_settings_apply (settings);
+ keyfile = g_key_file_new ();
+ g_assert (g_key_file_load_from_file (keyfile, "keyfile/gsettings.store", 0, NULL));
+
+ str = g_key_file_get_string (keyfile, "tests", "greeting", NULL);
+ g_assert (str == NULL);
+
+ called = FALSE;
g_signal_connect (settings, "changed::greeting", G_CALLBACK (key_changed_cb), &called);
- g_key_file_set_string (keyfile, "tests", "greeting", "howdy");
+ g_key_file_set_string (keyfile, "tests", "greeting", "'howdy'");
data = g_key_file_to_data (keyfile, &len, NULL);
- g_file_set_contents ("gsettings.store", data, len, &error);
+ g_file_set_contents ("keyfile/gsettings.store", data, len, &error);
g_assert_no_error (error);
while (!called)
g_main_context_iteration (NULL, FALSE);
+ g_signal_handlers_disconnect_by_func (settings, key_changed_cb, &called);
+
+ str = g_settings_get_string (settings, "greeting");
+ g_assert_cmpstr (str, ==, "howdy");
+ g_free (str);
+
+ g_settings_set (settings, "farewell", "s", "cheerio");
+
+ called = FALSE;
+ g_signal_connect (settings, "writable-changed::greeting", G_CALLBACK (key_changed_cb), &called);
+
+ g_chmod ("keyfile", 0500);
+ while (!called)
+ g_main_context_iteration (NULL, FALSE);
+ g_signal_handlers_disconnect_by_func (settings, key_changed_cb, &called);
+
+ writable = g_settings_is_writable (settings, "greeting");
+ g_assert (!writable);
g_key_file_free (keyfile);
g_free (data);
g_object_unref (settings);
+ g_chmod ("keyfile", 0777);
}
/* Test that getting child schemas works
g_assert_cmpint (g_settings_get_int (direct, "val"), ==, 1);
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 33);
+G_GNUC_BEGIN_IGNORE_DEPRECATIONS
value = g_variant_new_int32 (1);
g_assert (!g_settings_range_check (settings, "val", value));
g_variant_unref (value);
value = g_variant_new_int32 (45);
g_assert (!g_settings_range_check (settings, "val", value));
g_variant_unref (value);
+G_GNUC_END_IGNORE_DEPRECATIONS
}
static gboolean
const gchar * const *schemas;
const gchar * const *relocs;
+G_GNUC_BEGIN_IGNORE_DEPRECATIONS
relocs = g_settings_list_relocatable_schemas ();
schemas = g_settings_list_schemas ();
+G_GNUC_END_IGNORE_DEPRECATIONS
g_assert (strv_set_equal ((gchar **)relocs,
"org.gtk.test.no-path",
GSettings *settings;
GVariant *range;
+G_GNUC_BEGIN_IGNORE_DEPRECATIONS
settings = g_settings_new ("org.gtk.test.range");
range = g_settings_get_range (settings, "val");
check_and_free (range, "('range', <(2, 44)>)");
range = g_settings_get_range (settings, "greeting");
check_and_free (range, "('type', <@as []>)");
g_object_unref (settings);
+G_GNUC_END_IGNORE_DEPRECATIONS
}
static void
gboolean writable;
backend = g_null_settings_backend_new ();
- settings = g_settings_new_with_backend ("org.gtk.test", backend);
+ settings = g_settings_new_with_backend_and_path ("org.gtk.test", backend, "/tests/");
- g_object_get (settings, "schema", &str, NULL);
+ g_object_get (settings, "schema-id", &str, NULL);
g_assert_cmpstr (str, ==, "org.gtk.test");
g_free (str);
writable = g_settings_is_writable (settings, "greeting");
g_assert (!writable);
+ g_settings_reset (settings, "greeting");
+
+ g_settings_delay (settings);
+ g_settings_set (settings, "greeting", "s", "goodbye world");
+ g_settings_apply (settings);
+ g_settings_get (settings, "greeting", "s", &str);
+ g_assert_cmpstr (str, ==, "Hello, earthlings");
+ g_free (str);
+
g_object_unref (settings);
g_object_unref (backend);
}
GSettingsSchema *schema;
GSettingsSchemaKey *key;
GSettings *settings;
- const gchar *str;
settings = g_settings_new ("org.gtk.test");
g_object_get (settings, "settings-schema", &schema, NULL);
}
static void
+test_default_value (void)
+{
+ GSettings *settings;
+ GSettingsSchema *schema;
+ GSettingsSchemaKey *key;
+ GVariant *v;
+ const gchar *str;
+ gchar *s;
+
+ settings = g_settings_new ("org.gtk.test");
+ g_object_get (settings, "settings-schema", &schema, NULL);
+ key = g_settings_schema_get_key (schema, "greeting");
+ g_settings_schema_unref (schema);
+ g_settings_schema_key_ref (key);
+
+ g_assert (g_variant_type_equal (g_settings_schema_key_get_value_type (key), G_VARIANT_TYPE_STRING));
+
+ v = g_settings_schema_key_get_default_value (key);
+ str = g_variant_get_string (v, NULL);
+ g_assert_cmpstr (str, ==, "Hello, earthlings");
+ g_variant_unref (v);
+
+ g_settings_schema_key_unref (key);
+ g_settings_schema_key_unref (key);
+
+ g_settings_set (settings, "greeting", "s", "goodbye world");
+
+ v = g_settings_get_user_value (settings, "greeting");
+ str = g_variant_get_string (v, NULL);
+ g_assert_cmpstr (str, ==, "goodbye world");
+ g_variant_unref (v);
+
+ v = g_settings_get_default_value (settings, "greeting");
+ str = g_variant_get_string (v, NULL);
+ g_assert_cmpstr (str, ==, "Hello, earthlings");
+ g_variant_unref (v);
+
+ g_settings_reset (settings, "greeting");
+
+ v = g_settings_get_user_value (settings, "greeting");
+ g_assert_null (v);
+
+ s = g_settings_get_string (settings, "greeting");
+ g_assert_cmpstr (s, ==, "Hello, earthlings");
+ g_free (s);
+
+ g_object_unref (settings);
+}
+
+static void
test_extended_schema (void)
{
GSettings *settings;
int
main (int argc, char *argv[])
{
+ gchar *schema_text;
gchar *enums;
gint result;
g_assert (g_file_set_contents ("org.gtk.test.enums.xml", enums, -1, NULL));
g_free (enums);
+ g_assert (g_file_get_contents (SRCDIR "/org.gtk.test.gschema.xml.orig", &schema_text, NULL, NULL));
+ g_assert (g_file_set_contents ("org.gtk.test.gschema.xml", schema_text, -1, NULL));
+
g_remove ("gschemas.compiled");
g_assert (g_spawn_command_line_sync ("../glib-compile-schemas --targetdir=. "
"--schema-file=org.gtk.test.enums.xml "
- "--schema-file=" SRCDIR "/org.gtk.test.gschema.xml",
+ "--schema-file=org.gtk.test.gschema.xml",
NULL, NULL, &result, NULL));
g_assert (result == 0);
if (!backend_set)
{
g_test_add_func ("/gsettings/no-schema", test_no_schema);
- g_test_add_func ("/gsettings/no-schema/subprocess", test_no_schema_subprocess);
g_test_add_func ("/gsettings/unknown-key", test_unknown_key);
- g_test_add_func ("/gsettings/unknown-key/subprocess", test_unknown_key_subprocess);
g_test_add_func ("/gsettings/wrong-type", test_wrong_type);
g_test_add_func ("/gsettings/wrong-path", test_wrong_path);
- g_test_add_func ("/gsettings/wrong-path/subprocess", test_wrong_path_subprocess);
g_test_add_func ("/gsettings/no-path", test_no_path);
- g_test_add_func ("/gsettings/no-path/subprocess", test_no_path_subprocess);
}
g_test_add_func ("/gsettings/basic-types", test_basic_types);
g_test_add_func ("/gsettings/delay-apply", test_delay_apply);
g_test_add_func ("/gsettings/delay-revert", test_delay_revert);
+ g_test_add_func ("/gsettings/delay-child", test_delay_child);
g_test_add_func ("/gsettings/atomic", test_atomic);
g_test_add_func ("/gsettings/simple-binding", test_simple_binding);
if (!backend_set)
{
g_test_add_func ("/gsettings/typesafe-binding", test_typesafe_binding);
- g_test_add_func ("/gsettings/typesafe-binding/subprocess", test_typesafe_binding_subprocess);
g_test_add_func ("/gsettings/no-read-binding", test_no_read_binding);
g_test_add_func ("/gsettings/no-read-binding/subprocess/fail", test_no_read_binding_fail);
g_test_add_func ("/gsettings/no-read-binding/subprocess/pass", test_no_read_binding_pass);
g_test_add_func ("/gsettings/memory-backend", test_memory_backend);
g_test_add_func ("/gsettings/read-descriptions", test_read_descriptions);
g_test_add_func ("/gsettings/test-extended-schema", test_extended_schema);
+ g_test_add_func ("/gsettings/default-value", test_default_value);
result = g_test_run ();