2023-07-24 21:47:33 +02:00
|
|
|
|
#include "config.h"
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
#include <locale.h>
|
|
|
|
|
#include <libintl.h>
|
2014-05-11 23:38:27 +02:00
|
|
|
|
#include <unistd.h>
|
|
|
|
|
#include <sys/types.h>
|
2010-06-07 12:23:24 +02:00
|
|
|
|
#include <gio/gio.h>
|
2010-04-17 07:43:58 +02:00
|
|
|
|
#include <gstdio.h>
|
2010-04-18 03:19:45 +02:00
|
|
|
|
#define G_SETTINGS_ENABLE_BACKEND
|
|
|
|
|
#include <gio/gsettingsbackend.h>
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
#include "testenum.h"
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#ifdef HAVE_XLOCALE_H
|
|
|
|
|
/* Needed on macOS and FreeBSD for uselocale() */
|
|
|
|
|
#include <xlocale.h>
|
|
|
|
|
#endif
|
|
|
|
|
|
2017-02-24 10:46:36 +01:00
|
|
|
|
static const gchar *locale_dir = ".";
|
|
|
|
|
|
2010-06-11 04:35:31 +02:00
|
|
|
|
static gboolean backend_set;
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* These tests rely on the schemas in org.gtk.test.gschema.xml
|
|
|
|
|
* to be compiled and installed in the same directory.
|
|
|
|
|
*/
|
|
|
|
|
|
2019-03-04 13:27:28 +01:00
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
gchar *tmp_dir;
|
|
|
|
|
} Fixture;
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
setup (Fixture *fixture,
|
|
|
|
|
gconstpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
GError *error = NULL;
|
|
|
|
|
|
|
|
|
|
fixture->tmp_dir = g_dir_make_tmp ("gio-test-gsettings_XXXXXX", &error);
|
|
|
|
|
g_assert_no_error (error);
|
|
|
|
|
|
|
|
|
|
g_test_message ("Using temporary directory: %s", fixture->tmp_dir);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
teardown (Fixture *fixture,
|
|
|
|
|
gconstpointer user_data)
|
|
|
|
|
{
|
2020-10-31 13:24:22 +01:00
|
|
|
|
g_assert_no_errno (g_rmdir (fixture->tmp_dir));
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_clear_pointer (&fixture->tmp_dir, g_free);
|
|
|
|
|
}
|
|
|
|
|
|
2010-10-04 08:58:46 +02:00
|
|
|
|
static void
|
|
|
|
|
check_and_free (GVariant *value,
|
|
|
|
|
const gchar *expected)
|
|
|
|
|
{
|
|
|
|
|
gchar *printed;
|
|
|
|
|
|
|
|
|
|
printed = g_variant_print (value, TRUE);
|
|
|
|
|
g_assert_cmpstr (printed, ==, expected);
|
|
|
|
|
g_free (printed);
|
|
|
|
|
|
|
|
|
|
g_variant_unref (value);
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-16 12:40:38 +02:00
|
|
|
|
/* Wrapper around g_assert_cmpstr() which gets a setting from a #GSettings
|
|
|
|
|
* using g_settings_get(). */
|
|
|
|
|
#define settings_assert_cmpstr(settings, key, op, expected_value) G_STMT_START { \
|
|
|
|
|
gchar *__str; \
|
|
|
|
|
g_settings_get ((settings), (key), "s", &__str); \
|
|
|
|
|
g_assert_cmpstr (__str, op, (expected_value)); \
|
|
|
|
|
g_free (__str); \
|
|
|
|
|
} G_STMT_END
|
|
|
|
|
|
2010-10-04 08:58:46 +02:00
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Just to get warmed up: Read and set a string, and
|
|
|
|
|
* verify that can read the changed string back
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_basic (void)
|
|
|
|
|
{
|
|
|
|
|
gchar *str = NULL;
|
2013-11-28 18:58:44 +01:00
|
|
|
|
GObject *b;
|
|
|
|
|
gchar *path;
|
|
|
|
|
gboolean has_unapplied;
|
|
|
|
|
gboolean delay_apply;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
2013-11-28 18:58:44 +01:00
|
|
|
|
g_object_get (settings,
|
2014-06-23 14:53:06 +02:00
|
|
|
|
"schema-id", &str,
|
2013-11-28 18:58:44 +01:00
|
|
|
|
"backend", &b,
|
|
|
|
|
"path", &path,
|
|
|
|
|
"has-unapplied", &has_unapplied,
|
|
|
|
|
"delay-apply", &delay_apply,
|
|
|
|
|
NULL);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_assert_cmpstr (str, ==, "org.gtk.test");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (b);
|
2013-11-28 18:58:44 +01:00
|
|
|
|
g_assert_cmpstr (path, ==, "/tests/");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (has_unapplied);
|
|
|
|
|
g_assert_false (delay_apply);
|
2010-09-03 21:29:51 +02:00
|
|
|
|
g_free (str);
|
2013-11-28 18:58:44 +01:00
|
|
|
|
g_object_unref (b);
|
|
|
|
|
g_free (path);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "Hello, earthlings");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "goodbye world");
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "goodbye world");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (!backend_set && g_test_undefined ())
|
2010-04-17 07:43:58 +02:00
|
|
|
|
{
|
2012-08-24 23:11:17 +02:00
|
|
|
|
GSettings *tmp_settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"*g_settings_set_value*expects type*");
|
|
|
|
|
g_settings_set (tmp_settings, "greeting", "i", 555);
|
|
|
|
|
g_test_assert_expected_messages ();
|
|
|
|
|
|
|
|
|
|
g_object_unref (tmp_settings);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "goodbye world");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2010-07-23 00:39:50 +02:00
|
|
|
|
g_settings_reset (settings, "greeting");
|
|
|
|
|
str = g_settings_get_string (settings, "greeting");
|
|
|
|
|
g_assert_cmpstr (str, ==, "Hello, earthlings");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_set (settings, "greeting", "s", "this is the end");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Check that we get an error when getting a key
|
|
|
|
|
* that is not in the schema
|
|
|
|
|
*/
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_unknown_key (void)
|
|
|
|
|
{
|
|
|
|
|
if (!g_test_undefined ())
|
|
|
|
|
return;
|
|
|
|
|
|
2013-12-15 17:20:19 +01:00
|
|
|
|
if (g_test_subprocess ())
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GVariant *value;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
value = g_settings_get_value (settings, "no_such_key");
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (value);
|
2013-12-15 17:20:19 +01:00
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
return;
|
|
|
|
|
}
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess (NULL, 0, G_TEST_SUBPROCESS_DEFAULT);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*does not contain*");
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Check that we get an error when the schema
|
|
|
|
|
* has not been installed
|
|
|
|
|
*/
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_no_schema (void)
|
|
|
|
|
{
|
|
|
|
|
if (!g_test_undefined ())
|
|
|
|
|
return;
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2013-12-15 17:20:19 +01:00
|
|
|
|
if (g_test_subprocess ())
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("no.such.schema");
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (settings);
|
2013-12-15 17:20:19 +01:00
|
|
|
|
return;
|
|
|
|
|
}
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess (NULL, 0, G_TEST_SUBPROCESS_DEFAULT);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*Settings schema 'no.such.schema' is not installed*");
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Check that we get an error when passing a type string
|
|
|
|
|
* that does not match the schema
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_wrong_type (void)
|
|
|
|
|
{
|
2012-08-24 23:11:17 +02:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *str = NULL;
|
|
|
|
|
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (!g_test_undefined ())
|
|
|
|
|
return;
|
|
|
|
|
|
2012-08-24 23:11:17 +02:00
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2012-08-24 23:11:17 +02:00
|
|
|
|
g_test_expect_message ("GLib", G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"*given value has a type of*");
|
|
|
|
|
g_test_expect_message ("GLib", G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"*valid_format_string*");
|
|
|
|
|
g_settings_get (settings, "greeting", "o", &str);
|
|
|
|
|
g_test_assert_expected_messages ();
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (str);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2012-08-24 23:11:17 +02:00
|
|
|
|
g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"*expects type 's'*");
|
|
|
|
|
g_settings_set (settings, "greeting", "o", "/a/path");
|
|
|
|
|
g_test_assert_expected_messages ();
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2012-08-24 23:11:17 +02:00
|
|
|
|
g_object_unref (settings);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
/* Check errors with explicit paths */
|
|
|
|
|
static void
|
|
|
|
|
test_wrong_path (void)
|
|
|
|
|
{
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (!g_test_undefined ())
|
|
|
|
|
return;
|
|
|
|
|
|
2013-12-15 17:20:19 +01:00
|
|
|
|
if (g_test_subprocess ())
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings G_GNUC_UNUSED;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new_with_path ("org.gtk.test", "/wrong-path/");
|
|
|
|
|
return;
|
|
|
|
|
}
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess (NULL, 0, G_TEST_SUBPROCESS_DEFAULT);
|
2012-12-19 21:20:37 +01:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*but path * specified by schema*");
|
2012-11-24 22:34:13 +01:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_no_path (void)
|
|
|
|
|
{
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (!g_test_undefined ())
|
|
|
|
|
return;
|
|
|
|
|
|
2013-12-15 17:20:19 +01:00
|
|
|
|
if (g_test_subprocess ())
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings G_GNUC_UNUSED;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.no-path");
|
|
|
|
|
return;
|
|
|
|
|
}
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess (NULL, 0, G_TEST_SUBPROCESS_DEFAULT);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*attempting to create schema * without a path**");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Check that we can successfully read and set the full
|
|
|
|
|
* range of all basic types
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_basic_types (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gboolean b;
|
|
|
|
|
guint8 byte;
|
|
|
|
|
gint16 i16;
|
|
|
|
|
guint16 u16;
|
|
|
|
|
gint32 i32;
|
|
|
|
|
guint32 u32;
|
|
|
|
|
gint64 i64;
|
|
|
|
|
guint64 u64;
|
|
|
|
|
gdouble d;
|
|
|
|
|
gchar *str;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.basic-types");
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-boolean", "b", &b);
|
|
|
|
|
g_assert_cmpint (b, ==, 1);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-boolean", "b", 0);
|
|
|
|
|
g_settings_get (settings, "test-boolean", "b", &b);
|
|
|
|
|
g_assert_cmpint (b, ==, 0);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-byte", "y", &byte);
|
|
|
|
|
g_assert_cmpint (byte, ==, 25);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-byte", "y", G_MAXUINT8);
|
|
|
|
|
g_settings_get (settings, "test-byte", "y", &byte);
|
|
|
|
|
g_assert_cmpint (byte, ==, G_MAXUINT8);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-int16", "n", &i16);
|
|
|
|
|
g_assert_cmpint (i16, ==, -1234);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-int16", "n", G_MININT16);
|
|
|
|
|
g_settings_get (settings, "test-int16", "n", &i16);
|
|
|
|
|
g_assert_cmpint (i16, ==, G_MININT16);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-int16", "n", G_MAXINT16);
|
|
|
|
|
g_settings_get (settings, "test-int16", "n", &i16);
|
|
|
|
|
g_assert_cmpint (i16, ==, G_MAXINT16);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-uint16", "q", &u16);
|
|
|
|
|
g_assert_cmpuint (u16, ==, 1234);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-uint16", "q", G_MAXUINT16);
|
|
|
|
|
g_settings_get (settings, "test-uint16", "q", &u16);
|
|
|
|
|
g_assert_cmpuint (u16, ==, G_MAXUINT16);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-int32", "i", &i32);
|
|
|
|
|
g_assert_cmpint (i32, ==, -123456);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-int32", "i", G_MININT32);
|
|
|
|
|
g_settings_get (settings, "test-int32", "i", &i32);
|
|
|
|
|
g_assert_cmpint (i32, ==, G_MININT32);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-int32", "i", G_MAXINT32);
|
|
|
|
|
g_settings_get (settings, "test-int32", "i", &i32);
|
|
|
|
|
g_assert_cmpint (i32, ==, G_MAXINT32);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-uint32", "u", &u32);
|
|
|
|
|
g_assert_cmpuint (u32, ==, 123456);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-uint32", "u", G_MAXUINT32);
|
|
|
|
|
g_settings_get (settings, "test-uint32", "u", &u32);
|
|
|
|
|
g_assert_cmpuint (u32, ==, G_MAXUINT32);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-int64", "x", &i64);
|
|
|
|
|
g_assert_cmpuint (i64, ==, -123456789);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-int64", "x", G_MININT64);
|
|
|
|
|
g_settings_get (settings, "test-int64", "x", &i64);
|
|
|
|
|
g_assert_cmpuint (i64, ==, G_MININT64);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-int64", "x", G_MAXINT64);
|
|
|
|
|
g_settings_get (settings, "test-int64", "x", &i64);
|
|
|
|
|
g_assert_cmpuint (i64, ==, G_MAXINT64);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-uint64", "t", &u64);
|
|
|
|
|
g_assert_cmpuint (u64, ==, 123456789);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-uint64", "t", G_MAXUINT64);
|
|
|
|
|
g_settings_get (settings, "test-uint64", "t", &u64);
|
|
|
|
|
g_assert_cmpuint (u64, ==, G_MAXUINT64);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-double", "d", &d);
|
|
|
|
|
g_assert_cmpfloat (d, ==, 123.456);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-double", "d", G_MINDOUBLE);
|
|
|
|
|
g_settings_get (settings, "test-double", "d", &d);
|
|
|
|
|
g_assert_cmpfloat (d, ==, G_MINDOUBLE);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-double", "d", G_MAXDOUBLE);
|
|
|
|
|
g_settings_get (settings, "test-double", "d", &d);
|
|
|
|
|
g_assert_cmpfloat (d, ==, G_MAXDOUBLE);
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "test-string", ==, "a string, it seems");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-objectpath", "o", &str);
|
|
|
|
|
g_assert_cmpstr (str, ==, "/a/object/path");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
g_free (str);
|
|
|
|
|
str = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Check that we can read an set complex types like
|
|
|
|
|
* tuples, arrays and dictionaries
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_complex_types (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *s;
|
|
|
|
|
gint i1, i2;
|
|
|
|
|
GVariantIter *iter = NULL;
|
2016-09-26 12:21:20 +02:00
|
|
|
|
GVariant *v = NULL;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.complex-types");
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-tuple", "(s(ii))", &s, &i1, &i2);
|
|
|
|
|
g_assert_cmpstr (s, ==, "one");
|
|
|
|
|
g_assert_cmpint (i1,==, 2);
|
|
|
|
|
g_assert_cmpint (i2,==, 3);
|
|
|
|
|
g_free (s) ;
|
|
|
|
|
s = NULL;
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "test-tuple", "(s(ii))", "none", 0, 0);
|
|
|
|
|
g_settings_get (settings, "test-tuple", "(s(ii))", &s, &i1, &i2);
|
|
|
|
|
g_assert_cmpstr (s, ==, "none");
|
|
|
|
|
g_assert_cmpint (i1,==, 0);
|
|
|
|
|
g_assert_cmpint (i2,==, 0);
|
|
|
|
|
g_free (s);
|
|
|
|
|
s = NULL;
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-array", "ai", &iter);
|
|
|
|
|
g_assert_cmpint (g_variant_iter_n_children (iter), ==, 6);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_assert_cmpint (i1, ==, 0);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_assert_cmpint (i1, ==, 1);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_assert_cmpint (i1, ==, 2);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_assert_cmpint (i1, ==, 3);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_assert_cmpint (i1, ==, 4);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_assert_cmpint (i1, ==, 5);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (g_variant_iter_next (iter, "i", &i1));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_variant_iter_free (iter);
|
|
|
|
|
|
2016-09-26 12:21:20 +02:00
|
|
|
|
g_settings_get (settings, "test-dict", "a{sau}", &iter);
|
|
|
|
|
g_assert_cmpint (g_variant_iter_n_children (iter), ==, 2);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "{&s@au}", &s, &v));
|
2016-09-26 12:21:20 +02:00
|
|
|
|
g_assert_cmpstr (s, ==, "AC");
|
|
|
|
|
g_assert_cmpstr ((char *)g_variant_get_type (v), ==, "au");
|
|
|
|
|
g_variant_unref (v);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_iter_next (iter, "{&s@au}", &s, &v));
|
2016-09-26 12:21:20 +02:00
|
|
|
|
g_assert_cmpstr (s, ==, "IV");
|
|
|
|
|
g_assert_cmpstr ((char *)g_variant_get_type (v), ==, "au");
|
|
|
|
|
g_variant_unref (v);
|
|
|
|
|
g_variant_iter_free (iter);
|
|
|
|
|
|
|
|
|
|
v = g_settings_get_value (settings, "test-dict");
|
|
|
|
|
g_assert_cmpstr ((char *)g_variant_get_type (v), ==, "a{sau}");
|
|
|
|
|
g_variant_unref (v);
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static gboolean changed_cb_called;
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
changed_cb (GSettings *settings,
|
|
|
|
|
const gchar *key,
|
|
|
|
|
gpointer data)
|
|
|
|
|
{
|
|
|
|
|
changed_cb_called = TRUE;
|
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (key, ==, data);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test that basic change notification with the changed signal works.
|
|
|
|
|
*/
|
2011-10-17 03:11:11 +02:00
|
|
|
|
static void
|
2010-04-17 07:43:58 +02:00
|
|
|
|
test_changes (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GSettings *settings2;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
g_signal_connect (settings, "changed",
|
|
|
|
|
G_CALLBACK (changed_cb), "greeting");
|
|
|
|
|
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "new greeting");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (changed_cb_called);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
settings2 = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings2, "greeting", "s", "hi");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (changed_cb_called);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_object_unref (settings2);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static gboolean changed_cb_called2;
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
changed_cb2 (GSettings *settings,
|
|
|
|
|
const gchar *key,
|
|
|
|
|
gpointer data)
|
|
|
|
|
{
|
|
|
|
|
gboolean *p = data;
|
|
|
|
|
|
|
|
|
|
*p = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test that changes done to a delay-mode instance
|
|
|
|
|
* don't appear to the outside world until apply. Also
|
|
|
|
|
* check that we get change notification when they are
|
|
|
|
|
* applied.
|
|
|
|
|
* Also test that the has-unapplied property is properly
|
|
|
|
|
* maintained.
|
|
|
|
|
*/
|
2011-10-17 03:11:11 +02:00
|
|
|
|
static void
|
2010-04-17 07:43:58 +02:00
|
|
|
|
test_delay_apply (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GSettings *settings2;
|
2013-06-03 02:00:21 +02:00
|
|
|
|
gboolean writable;
|
2013-12-21 18:51:22 +01:00
|
|
|
|
GVariant *v;
|
|
|
|
|
const gchar *s;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
settings2 = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings2, "greeting", "s", "top o' the morning");
|
|
|
|
|
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
changed_cb_called2 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_signal_connect (settings, "changed",
|
|
|
|
|
G_CALLBACK (changed_cb2), &changed_cb_called);
|
|
|
|
|
g_signal_connect (settings2, "changed",
|
|
|
|
|
G_CALLBACK (changed_cb2), &changed_cb_called2);
|
|
|
|
|
|
|
|
|
|
g_settings_delay (settings);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "greetings from test_delay_apply");
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (changed_cb_called);
|
|
|
|
|
g_assert_false (changed_cb_called2);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2018-02-02 11:13:23 +01:00
|
|
|
|
/* Try resetting the key and ensure a notification is emitted on the delayed #GSettings object. */
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
changed_cb_called2 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_settings_reset (settings, "greeting");
|
|
|
|
|
|
|
|
|
|
g_assert_true (changed_cb_called);
|
|
|
|
|
g_assert_false (changed_cb_called2);
|
|
|
|
|
|
|
|
|
|
/* Locally change the greeting again. */
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
changed_cb_called2 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "greetings from test_delay_apply");
|
|
|
|
|
|
|
|
|
|
g_assert_true (changed_cb_called);
|
|
|
|
|
g_assert_false (changed_cb_called2);
|
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
writable = g_settings_is_writable (settings, "greeting");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (writable);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "greetings from test_delay_apply");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2013-12-21 18:51:22 +01:00
|
|
|
|
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);
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings2, "greeting", ==, "top o' the morning");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_settings_get_has_unapplied (settings));
|
|
|
|
|
g_assert_false (g_settings_get_has_unapplied (settings2));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
changed_cb_called2 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (changed_cb_called);
|
|
|
|
|
g_assert_true (changed_cb_called2);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "greetings from test_delay_apply");
|
|
|
|
|
settings_assert_cmpstr (settings2, "greeting", ==, "greetings from test_delay_apply");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (g_settings_get_has_unapplied (settings));
|
|
|
|
|
g_assert_false (g_settings_get_has_unapplied (settings2));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_settings_reset (settings, "greeting");
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "Hello, earthlings");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_unref (settings2);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test that reverting unapplied changes in a delay-apply
|
|
|
|
|
* settings instance works.
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_delay_revert (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GSettings *settings2;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
settings2 = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings2, "greeting", "s", "top o' the morning");
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "top o' the morning");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_delay (settings);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "greetings from test_delay_revert");
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "greetings from test_delay_revert");
|
|
|
|
|
settings_assert_cmpstr (settings2, "greeting", ==, "top o' the morning");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_settings_get_has_unapplied (settings));
|
2010-04-17 22:13:22 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_revert (settings);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (g_settings_get_has_unapplied (settings));
|
2010-04-17 22:13:22 +02:00
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "top o' the morning");
|
|
|
|
|
settings_assert_cmpstr (settings2, "greeting", ==, "top o' the morning");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_object_unref (settings2);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2013-12-21 18:51:22 +01:00
|
|
|
|
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);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (delay);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
|
|
|
|
|
child = g_settings_get_child (settings, "basic-types");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (child);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
|
|
|
|
|
g_object_get (child, "delay-apply", &delay, NULL);
|
2021-10-26 15:10:19 +02:00
|
|
|
|
g_assert_true (delay);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
|
|
|
|
|
g_settings_get (child, "test-byte", "y", &byte);
|
|
|
|
|
g_assert_cmpuint (byte, ==, 36);
|
|
|
|
|
|
|
|
|
|
g_settings_set (child, "test-byte", "y", 42);
|
|
|
|
|
|
2014-01-02 07:55:07 +01:00
|
|
|
|
/* make sure the child was delayed too */
|
2013-12-21 18:51:22 +01:00
|
|
|
|
g_settings_get (base, "test-byte", "y", &byte);
|
2014-01-02 07:55:07 +01:00
|
|
|
|
g_assert_cmpuint (byte, ==, 36);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
|
2021-10-26 15:10:19 +02:00
|
|
|
|
/* apply the child and the changes should be saved */
|
|
|
|
|
g_settings_apply (child);
|
|
|
|
|
g_settings_get (base, "test-byte", "y", &byte);
|
|
|
|
|
g_assert_cmpuint (byte, ==, 42);
|
|
|
|
|
|
2013-12-21 18:51:22 +01:00
|
|
|
|
g_object_unref (child);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
g_object_unref (base);
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-16 12:40:38 +02:00
|
|
|
|
static void
|
|
|
|
|
test_delay_reset_key (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *direct_settings = NULL, *delayed_settings = NULL;
|
|
|
|
|
|
|
|
|
|
g_test_summary ("Test that resetting a key on a delayed settings instance works");
|
|
|
|
|
|
|
|
|
|
delayed_settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
direct_settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
g_settings_set (direct_settings, "greeting", "s", "ey up");
|
|
|
|
|
|
|
|
|
|
settings_assert_cmpstr (delayed_settings, "greeting", ==, "ey up");
|
|
|
|
|
|
|
|
|
|
/* Set up a delayed settings backend. */
|
|
|
|
|
g_settings_delay (delayed_settings);
|
|
|
|
|
|
|
|
|
|
g_settings_set (delayed_settings, "greeting", "s", "how do");
|
|
|
|
|
|
|
|
|
|
settings_assert_cmpstr (delayed_settings, "greeting", ==, "how do");
|
|
|
|
|
settings_assert_cmpstr (direct_settings, "greeting", ==, "ey up");
|
|
|
|
|
|
|
|
|
|
g_assert_true (g_settings_get_has_unapplied (delayed_settings));
|
|
|
|
|
|
|
|
|
|
g_settings_reset (delayed_settings, "greeting");
|
|
|
|
|
|
|
|
|
|
/* There are still unapplied settings, because the reset is resetting to the
|
|
|
|
|
* value from the schema, not the value from @direct_settings. */
|
|
|
|
|
g_assert_true (g_settings_get_has_unapplied (delayed_settings));
|
|
|
|
|
|
|
|
|
|
settings_assert_cmpstr (delayed_settings, "greeting", ==, "Hello, earthlings");
|
|
|
|
|
settings_assert_cmpstr (direct_settings, "greeting", ==, "ey up");
|
|
|
|
|
|
|
|
|
|
/* Apply the settings changes (i.e. the reset). */
|
|
|
|
|
g_settings_apply (delayed_settings);
|
|
|
|
|
|
|
|
|
|
g_assert_false (g_settings_get_has_unapplied (delayed_settings));
|
|
|
|
|
|
|
|
|
|
settings_assert_cmpstr (delayed_settings, "greeting", ==, "Hello, earthlings");
|
|
|
|
|
settings_assert_cmpstr (direct_settings, "greeting", ==, "Hello, earthlings");
|
|
|
|
|
|
|
|
|
|
g_object_unref (direct_settings);
|
|
|
|
|
g_object_unref (delayed_settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
keys_changed_cb (GSettings *settings,
|
|
|
|
|
const GQuark *keys,
|
|
|
|
|
gint n_keys)
|
|
|
|
|
{
|
|
|
|
|
g_assert_cmpint (n_keys, ==, 2);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true ((keys[0] == g_quark_from_static_string ("greeting") &&
|
|
|
|
|
keys[1] == g_quark_from_static_string ("farewell")) ||
|
|
|
|
|
(keys[1] == g_quark_from_static_string ("greeting") &&
|
|
|
|
|
keys[0] == g_quark_from_static_string ("farewell")));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "greetings from test_atomic");
|
|
|
|
|
settings_assert_cmpstr (settings, "farewell", ==, "atomic bye-bye");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Check that delay-applied changes appear atomically.
|
|
|
|
|
* More specifically, verify that all changed keys appear
|
|
|
|
|
* with their new value while handling the change-event signal.
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_atomic (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GSettings *settings2;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
settings2 = g_settings_new ("org.gtk.test");
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings2, "greeting", "s", "top o' the morning");
|
|
|
|
|
|
|
|
|
|
changed_cb_called = FALSE;
|
|
|
|
|
changed_cb_called2 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_signal_connect (settings2, "change-event",
|
|
|
|
|
G_CALLBACK (keys_changed_cb), NULL);
|
|
|
|
|
|
|
|
|
|
g_settings_delay (settings);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "greetings from test_atomic");
|
|
|
|
|
g_settings_set (settings, "farewell", "s", "atomic bye-bye");
|
|
|
|
|
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "greetings from test_atomic");
|
|
|
|
|
settings_assert_cmpstr (settings, "farewell", ==, "atomic bye-bye");
|
|
|
|
|
settings_assert_cmpstr (settings2, "greeting", ==, "greetings from test_atomic");
|
|
|
|
|
settings_assert_cmpstr (settings2, "farewell", ==, "atomic bye-bye");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_object_unref (settings2);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-19 15:13:13 +02:00
|
|
|
|
/* On Windows the interaction between the C library locale and libintl
|
|
|
|
|
* (from GNU gettext) is not like on POSIX, so just skip these tests
|
|
|
|
|
* for now.
|
|
|
|
|
*
|
|
|
|
|
* There are several issues:
|
|
|
|
|
*
|
|
|
|
|
* 1) The C library doesn't use LC_MESSAGES, that is implemented only
|
|
|
|
|
* in libintl (defined in its <libintl.h>).
|
|
|
|
|
*
|
2023-07-24 21:47:33 +02:00
|
|
|
|
* 2) The locale names that uselocale() accepts and returns aren't in
|
2010-04-19 15:13:13 +02:00
|
|
|
|
* the "de_DE" style, but like "German_Germany".
|
|
|
|
|
*
|
|
|
|
|
* 3) libintl looks at the Win32 thread locale and not the C library
|
|
|
|
|
* locale. (And even if libintl would use the C library's locale, as
|
|
|
|
|
* there are several alternative C library DLLs, libintl might be
|
|
|
|
|
* linked to a different one than the application code, so they
|
|
|
|
|
* wouldn't have the same C library locale anyway.)
|
|
|
|
|
*/
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test that translations work for schema defaults.
|
|
|
|
|
*
|
|
|
|
|
* This test relies on the de.po file in the same directory
|
|
|
|
|
* to be compiled into ./de/LC_MESSAGES/test.mo
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_l10n (void)
|
|
|
|
|
{
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#ifndef HAVE_USELOCALE
|
|
|
|
|
g_test_skip ("Unsafe to change locale because platform does not support uselocale()");
|
|
|
|
|
#else
|
2010-04-17 07:43:58 +02:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *str;
|
2023-07-24 21:47:33 +02:00
|
|
|
|
locale_t original_locale;
|
|
|
|
|
locale_t new_locale;
|
|
|
|
|
locale_t result;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2017-02-24 10:46:36 +01:00
|
|
|
|
bindtextdomain ("test", locale_dir);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
bind_textdomain_codeset ("test", "UTF-8");
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
original_locale = uselocale ((locale_t) 0);
|
|
|
|
|
g_assert_true (original_locale != (locale_t) 0);
|
|
|
|
|
new_locale = newlocale (LC_MESSAGES_MASK, "C", (locale_t) 0);
|
|
|
|
|
g_assert_true (new_locale != (locale_t) 0);
|
|
|
|
|
result = uselocale (new_locale);
|
|
|
|
|
g_assert_true (result == original_locale);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.localized");
|
|
|
|
|
str = g_settings_get_string (settings, "error-message");
|
2023-07-24 21:47:33 +02:00
|
|
|
|
|
|
|
|
|
result = uselocale (original_locale);
|
|
|
|
|
g_assert_true (result == new_locale);
|
|
|
|
|
freelocale (new_locale);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (str, ==, "Unnamed");
|
|
|
|
|
g_free (str);
|
|
|
|
|
str = NULL;
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
new_locale = newlocale (LC_MESSAGES_MASK, "de_DE.UTF-8", (locale_t) 0);
|
|
|
|
|
if (new_locale == (locale_t) 0)
|
|
|
|
|
{
|
|
|
|
|
g_test_skip ("Cannot run test becaues de_DE.UTF-8 locale is not available");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
result = uselocale (new_locale);
|
|
|
|
|
g_assert_true (result == original_locale);
|
|
|
|
|
|
Rework the build system for a new tests approach
Perform a substantial cleanup of the build system with respect to
building and installing testcases.
First, Makefile.decl has been renamed glib.mk and substantially
expanded. We intend to add more stuff here in the future, like canned
rules for mkenums, marshallers, resources, etc.
By default, tests are no longer compiled as part of 'make'. They will
be built when 'make check' is run. The old behaviour can be obtained
with --enable-always-build-tests.
--disable-modular-tests is gone (because tests are no longer built by
default). There is no longer any way to cause 'make check' to be a
no-op, but that's not very useful anyway.
A new glibtests.m4 file is introduced. Along with glib.mk, this
provides for consistent handling of --enable-installed-tests and
--enable-always-build-tests (mentioned above).
Port our various test-installing Makefiles to the new framework.
This patch substantially improves the situation in the toplevel tests/
directory. Things are now somewhat under control there. There were
some tests being built that weren't even being run and we run those now.
The long-running GObject performance tests in this directory have been
removed from 'make check' because they take too long.
As an experiment, 'make check' now runs the testcases on win32 builds,
by default. We can't run them under gtester (since it uses a pipe to
communicate with the subprocess) so just toss them in TESTS. Most of
them are passing on win32.
Things are not quite done here, but this patch is already a substantial
improvement. More to come.
2013-05-30 06:07:32 +02:00
|
|
|
|
/* Only do the test if translation is actually working... */
|
|
|
|
|
if (g_str_equal (dgettext ("test", "\"Unnamed\""), "\"Unbenannt\""))
|
|
|
|
|
{
|
|
|
|
|
str = g_settings_get_string (settings, "error-message");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
Rework the build system for a new tests approach
Perform a substantial cleanup of the build system with respect to
building and installing testcases.
First, Makefile.decl has been renamed glib.mk and substantially
expanded. We intend to add more stuff here in the future, like canned
rules for mkenums, marshallers, resources, etc.
By default, tests are no longer compiled as part of 'make'. They will
be built when 'make check' is run. The old behaviour can be obtained
with --enable-always-build-tests.
--disable-modular-tests is gone (because tests are no longer built by
default). There is no longer any way to cause 'make check' to be a
no-op, but that's not very useful anyway.
A new glibtests.m4 file is introduced. Along with glib.mk, this
provides for consistent handling of --enable-installed-tests and
--enable-always-build-tests (mentioned above).
Port our various test-installing Makefiles to the new framework.
This patch substantially improves the situation in the toplevel tests/
directory. Things are now somewhat under control there. There were
some tests being built that weren't even being run and we run those now.
The long-running GObject performance tests in this directory have been
removed from 'make check' because they take too long.
As an experiment, 'make check' now runs the testcases on win32 builds,
by default. We can't run them under gtester (since it uses a pipe to
communicate with the subprocess) so just toss them in TESTS. Most of
them are passing on win32.
Things are not quite done here, but this patch is already a substantial
improvement. More to come.
2013-05-30 06:07:32 +02:00
|
|
|
|
g_assert_cmpstr (str, ==, "Unbenannt");
|
|
|
|
|
g_free (str);
|
|
|
|
|
str = NULL;
|
|
|
|
|
}
|
|
|
|
|
else
|
2023-01-17 19:12:55 +01:00
|
|
|
|
{
|
|
|
|
|
g_test_skip ("translation is not working");
|
|
|
|
|
}
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
result = uselocale (original_locale);
|
|
|
|
|
g_assert_true (result == new_locale);
|
|
|
|
|
freelocale (new_locale);
|
|
|
|
|
|
2016-07-08 11:04:37 +02:00
|
|
|
|
g_object_unref (settings);
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#endif
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test that message context works as expected with translated
|
|
|
|
|
* schema defaults. Also, verify that non-ASCII UTF-8 content
|
|
|
|
|
* works.
|
|
|
|
|
*
|
|
|
|
|
* This test relies on the de.po file in the same directory
|
|
|
|
|
* to be compiled into ./de/LC_MESSAGES/test.mo
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_l10n_context (void)
|
|
|
|
|
{
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#ifndef HAVE_USELOCALE
|
|
|
|
|
g_test_skip ("Unsafe to change locale because platform does not support uselocale()");
|
|
|
|
|
#else
|
2010-04-17 07:43:58 +02:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *str;
|
2023-07-24 21:47:33 +02:00
|
|
|
|
locale_t original_locale;
|
|
|
|
|
locale_t new_locale;
|
|
|
|
|
locale_t result;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2017-02-24 10:46:36 +01:00
|
|
|
|
bindtextdomain ("test", locale_dir);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
bind_textdomain_codeset ("test", "UTF-8");
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.localized");
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
original_locale = uselocale ((locale_t) 0);
|
|
|
|
|
g_assert_true (original_locale != (locale_t) 0);
|
|
|
|
|
new_locale = newlocale (LC_MESSAGES_MASK, "C", (locale_t) 0);
|
|
|
|
|
g_assert_true (new_locale != (locale_t) 0);
|
|
|
|
|
result = uselocale (new_locale);
|
|
|
|
|
g_assert_true (result == original_locale);
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_get (settings, "backspace", "s", &str);
|
2023-07-24 21:47:33 +02:00
|
|
|
|
|
|
|
|
|
result = uselocale (original_locale);
|
|
|
|
|
g_assert_true (result == new_locale);
|
|
|
|
|
freelocale (new_locale);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (str, ==, "BackSpace");
|
|
|
|
|
g_free (str);
|
|
|
|
|
str = NULL;
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
new_locale = newlocale (LC_MESSAGES_MASK, "de_DE.UTF-8", (locale_t) 0);
|
|
|
|
|
if (new_locale == (locale_t) 0)
|
|
|
|
|
{
|
|
|
|
|
g_test_skip ("Cannot run test becaues de_DE.UTF-8 locale is not available");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
result = uselocale (new_locale);
|
|
|
|
|
g_assert_true (result == original_locale);
|
|
|
|
|
|
Rework the build system for a new tests approach
Perform a substantial cleanup of the build system with respect to
building and installing testcases.
First, Makefile.decl has been renamed glib.mk and substantially
expanded. We intend to add more stuff here in the future, like canned
rules for mkenums, marshallers, resources, etc.
By default, tests are no longer compiled as part of 'make'. They will
be built when 'make check' is run. The old behaviour can be obtained
with --enable-always-build-tests.
--disable-modular-tests is gone (because tests are no longer built by
default). There is no longer any way to cause 'make check' to be a
no-op, but that's not very useful anyway.
A new glibtests.m4 file is introduced. Along with glib.mk, this
provides for consistent handling of --enable-installed-tests and
--enable-always-build-tests (mentioned above).
Port our various test-installing Makefiles to the new framework.
This patch substantially improves the situation in the toplevel tests/
directory. Things are now somewhat under control there. There were
some tests being built that weren't even being run and we run those now.
The long-running GObject performance tests in this directory have been
removed from 'make check' because they take too long.
As an experiment, 'make check' now runs the testcases on win32 builds,
by default. We can't run them under gtester (since it uses a pipe to
communicate with the subprocess) so just toss them in TESTS. Most of
them are passing on win32.
Things are not quite done here, but this patch is already a substantial
improvement. More to come.
2013-05-30 06:07:32 +02:00
|
|
|
|
/* Only do the test if translation is actually working... */
|
|
|
|
|
if (g_str_equal (dgettext ("test", "\"Unnamed\""), "\"Unbenannt\""))
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "backspace", ==, "Löschen");
|
Rework the build system for a new tests approach
Perform a substantial cleanup of the build system with respect to
building and installing testcases.
First, Makefile.decl has been renamed glib.mk and substantially
expanded. We intend to add more stuff here in the future, like canned
rules for mkenums, marshallers, resources, etc.
By default, tests are no longer compiled as part of 'make'. They will
be built when 'make check' is run. The old behaviour can be obtained
with --enable-always-build-tests.
--disable-modular-tests is gone (because tests are no longer built by
default). There is no longer any way to cause 'make check' to be a
no-op, but that's not very useful anyway.
A new glibtests.m4 file is introduced. Along with glib.mk, this
provides for consistent handling of --enable-installed-tests and
--enable-always-build-tests (mentioned above).
Port our various test-installing Makefiles to the new framework.
This patch substantially improves the situation in the toplevel tests/
directory. Things are now somewhat under control there. There were
some tests being built that weren't even being run and we run those now.
The long-running GObject performance tests in this directory have been
removed from 'make check' because they take too long.
As an experiment, 'make check' now runs the testcases on win32 builds,
by default. We can't run them under gtester (since it uses a pipe to
communicate with the subprocess) so just toss them in TESTS. Most of
them are passing on win32.
Things are not quite done here, but this patch is already a substantial
improvement. More to come.
2013-05-30 06:07:32 +02:00
|
|
|
|
else
|
2023-01-17 19:12:55 +01:00
|
|
|
|
g_test_skip ("translation is not working");
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
result = uselocale (original_locale);
|
|
|
|
|
g_assert_true (result == new_locale);
|
|
|
|
|
freelocale (new_locale);
|
|
|
|
|
|
2016-07-08 11:04:37 +02:00
|
|
|
|
g_object_unref (settings);
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#endif
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|
|
|
|
|
|
2023-07-21 20:48:34 +02:00
|
|
|
|
/* Test use of l10n="time" and LC_TIME. */
|
|
|
|
|
static void
|
|
|
|
|
test_l10n_time (void)
|
|
|
|
|
{
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#ifndef HAVE_USELOCALE
|
|
|
|
|
g_test_skip ("Unsafe to change locale because platform does not support uselocale()");
|
|
|
|
|
#else
|
2023-07-21 20:48:34 +02:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *str;
|
2023-07-24 21:47:33 +02:00
|
|
|
|
locale_t original_locale;
|
|
|
|
|
locale_t new_locale;
|
|
|
|
|
locale_t result;
|
2023-07-21 20:48:34 +02:00
|
|
|
|
|
|
|
|
|
g_test_summary ("Test that l10n='time' attribute uses the correct category for translations");
|
|
|
|
|
g_test_bug ("https://gitlab.gnome.org/GNOME/glib/-/issues/2575");
|
|
|
|
|
|
|
|
|
|
bindtextdomain ("test", locale_dir);
|
|
|
|
|
bind_textdomain_codeset ("test", "UTF-8");
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.localized");
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
original_locale = uselocale ((locale_t) 0);
|
|
|
|
|
g_assert_true (original_locale != (locale_t) 0);
|
|
|
|
|
new_locale = duplocale (original_locale);
|
|
|
|
|
g_assert_true (new_locale != (locale_t) 0);
|
2024-05-08 23:02:39 +02:00
|
|
|
|
g_clear_pointer (&new_locale, freelocale);
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
new_locale = newlocale (LC_TIME_MASK, "C", new_locale);
|
|
|
|
|
g_assert_true (new_locale != (locale_t) 0);
|
|
|
|
|
result = uselocale (new_locale);
|
|
|
|
|
g_assert_true (result == original_locale);
|
|
|
|
|
|
2023-07-21 20:48:34 +02:00
|
|
|
|
str = g_settings_get_string (settings, "midnight");
|
2023-07-24 21:47:33 +02:00
|
|
|
|
|
|
|
|
|
result = uselocale (original_locale);
|
|
|
|
|
g_assert_true (result == new_locale);
|
2023-07-21 20:48:34 +02:00
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (str, ==, "12:00 AM");
|
|
|
|
|
g_free (str);
|
2024-05-08 23:02:39 +02:00
|
|
|
|
g_clear_pointer (&new_locale, freelocale);
|
2023-07-21 20:48:34 +02:00
|
|
|
|
str = NULL;
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
new_locale = newlocale (LC_TIME_MASK, "de_DE.UTF-8", new_locale);
|
|
|
|
|
if (new_locale == (locale_t) 0)
|
|
|
|
|
{
|
|
|
|
|
g_test_skip ("Cannot run test becaues de_DE.UTF-8 locale is not available");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
result = uselocale (new_locale);
|
|
|
|
|
g_assert_true (result != (locale_t) 0);
|
|
|
|
|
|
2023-07-21 20:48:34 +02:00
|
|
|
|
/* Only do the test if translation is actually working... */
|
|
|
|
|
if (g_str_equal (dgettext ("test", "\"12:00 AM\""), "\"00:00\""))
|
|
|
|
|
{
|
|
|
|
|
str = g_settings_get_string (settings, "midnight");
|
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (str, ==, "00:00");
|
|
|
|
|
g_free (str);
|
|
|
|
|
str = NULL;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
g_test_skip ("translation is not working");
|
|
|
|
|
}
|
|
|
|
|
|
2023-07-24 21:47:33 +02:00
|
|
|
|
result = uselocale (original_locale);
|
|
|
|
|
g_assert_true (result == new_locale);
|
2024-05-08 23:02:39 +02:00
|
|
|
|
g_clear_pointer (&new_locale, freelocale);
|
2023-07-24 21:47:33 +02:00
|
|
|
|
|
2023-07-21 20:48:34 +02:00
|
|
|
|
g_object_unref (settings);
|
2023-07-24 21:47:33 +02:00
|
|
|
|
#endif
|
2023-07-21 20:48:34 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
enum
|
|
|
|
|
{
|
|
|
|
|
PROP_0,
|
|
|
|
|
PROP_BOOL,
|
2010-08-03 08:08:03 +02:00
|
|
|
|
PROP_ANTI_BOOL,
|
2010-07-05 21:53:58 +02:00
|
|
|
|
PROP_BYTE,
|
|
|
|
|
PROP_INT16,
|
|
|
|
|
PROP_UINT16,
|
2010-04-17 07:43:58 +02:00
|
|
|
|
PROP_INT,
|
2010-07-05 21:53:58 +02:00
|
|
|
|
PROP_UINT,
|
2010-04-19 16:00:03 +02:00
|
|
|
|
PROP_INT64,
|
|
|
|
|
PROP_UINT64,
|
2010-04-17 07:43:58 +02:00
|
|
|
|
PROP_DOUBLE,
|
2010-04-21 18:31:10 +02:00
|
|
|
|
PROP_STRING,
|
|
|
|
|
PROP_NO_READ,
|
2010-07-05 18:08:17 +02:00
|
|
|
|
PROP_NO_WRITE,
|
2010-07-22 05:10:31 +02:00
|
|
|
|
PROP_STRV,
|
2012-08-19 08:24:04 +02:00
|
|
|
|
PROP_ENUM,
|
|
|
|
|
PROP_FLAGS
|
2010-04-17 07:43:58 +02:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
GObject parent_instance;
|
|
|
|
|
|
|
|
|
|
gboolean bool_prop;
|
2010-08-03 08:08:03 +02:00
|
|
|
|
gboolean anti_bool_prop;
|
2011-09-22 22:08:35 +02:00
|
|
|
|
gint8 byte_prop;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
gint int16_prop;
|
|
|
|
|
guint16 uint16_prop;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
gint int_prop;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
guint uint_prop;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
gint64 int64_prop;
|
|
|
|
|
guint64 uint64_prop;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
gdouble double_prop;
|
|
|
|
|
gchar *string_prop;
|
2010-04-21 18:31:10 +02:00
|
|
|
|
gchar *no_read_prop;
|
|
|
|
|
gchar *no_write_prop;
|
2010-07-22 05:10:31 +02:00
|
|
|
|
gchar **strv_prop;
|
2010-07-05 18:08:17 +02:00
|
|
|
|
guint enum_prop;
|
2012-08-19 08:24:04 +02:00
|
|
|
|
guint flags_prop;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
} TestObject;
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
GObjectClass parent_class;
|
|
|
|
|
} TestObjectClass;
|
|
|
|
|
|
2011-10-17 03:11:11 +02:00
|
|
|
|
static GType test_object_get_type (void);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
G_DEFINE_TYPE (TestObject, test_object, G_TYPE_OBJECT)
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_object_init (TestObject *object)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_object_finalize (GObject *object)
|
|
|
|
|
{
|
|
|
|
|
TestObject *testo = (TestObject*)object;
|
2010-07-22 05:10:31 +02:00
|
|
|
|
g_strfreev (testo->strv_prop);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_free (testo->string_prop);
|
|
|
|
|
G_OBJECT_CLASS (test_object_parent_class)->finalize (object);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_object_get_property (GObject *object,
|
|
|
|
|
guint prop_id,
|
|
|
|
|
GValue *value,
|
|
|
|
|
GParamSpec *pspec)
|
|
|
|
|
{
|
|
|
|
|
TestObject *test_object = (TestObject *)object;
|
|
|
|
|
|
|
|
|
|
switch (prop_id)
|
|
|
|
|
{
|
|
|
|
|
case PROP_BOOL:
|
|
|
|
|
g_value_set_boolean (value, test_object->bool_prop);
|
|
|
|
|
break;
|
2010-08-03 08:08:03 +02:00
|
|
|
|
case PROP_ANTI_BOOL:
|
|
|
|
|
g_value_set_boolean (value, test_object->anti_bool_prop);
|
|
|
|
|
break;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
case PROP_BYTE:
|
2011-09-22 22:08:35 +02:00
|
|
|
|
g_value_set_schar (value, test_object->byte_prop);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
break;
|
|
|
|
|
case PROP_UINT16:
|
|
|
|
|
g_value_set_uint (value, test_object->uint16_prop);
|
|
|
|
|
break;
|
|
|
|
|
case PROP_INT16:
|
|
|
|
|
g_value_set_int (value, test_object->int16_prop);
|
|
|
|
|
break;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
case PROP_INT:
|
|
|
|
|
g_value_set_int (value, test_object->int_prop);
|
|
|
|
|
break;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
case PROP_UINT:
|
|
|
|
|
g_value_set_uint (value, test_object->uint_prop);
|
|
|
|
|
break;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
case PROP_INT64:
|
|
|
|
|
g_value_set_int64 (value, test_object->int64_prop);
|
|
|
|
|
break;
|
|
|
|
|
case PROP_UINT64:
|
|
|
|
|
g_value_set_uint64 (value, test_object->uint64_prop);
|
|
|
|
|
break;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
case PROP_DOUBLE:
|
|
|
|
|
g_value_set_double (value, test_object->double_prop);
|
|
|
|
|
break;
|
|
|
|
|
case PROP_STRING:
|
|
|
|
|
g_value_set_string (value, test_object->string_prop);
|
|
|
|
|
break;
|
2010-04-21 18:31:10 +02:00
|
|
|
|
case PROP_NO_WRITE:
|
|
|
|
|
g_value_set_string (value, test_object->no_write_prop);
|
|
|
|
|
break;
|
2010-07-22 05:10:31 +02:00
|
|
|
|
case PROP_STRV:
|
|
|
|
|
g_value_set_boxed (value, test_object->strv_prop);
|
|
|
|
|
break;
|
2010-07-05 18:08:17 +02:00
|
|
|
|
case PROP_ENUM:
|
|
|
|
|
g_value_set_enum (value, test_object->enum_prop);
|
|
|
|
|
break;
|
2012-08-19 08:24:04 +02:00
|
|
|
|
case PROP_FLAGS:
|
|
|
|
|
g_value_set_flags (value, test_object->flags_prop);
|
|
|
|
|
break;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
default:
|
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_object_set_property (GObject *object,
|
|
|
|
|
guint prop_id,
|
|
|
|
|
const GValue *value,
|
|
|
|
|
GParamSpec *pspec)
|
|
|
|
|
{
|
|
|
|
|
TestObject *test_object = (TestObject *)object;
|
|
|
|
|
|
|
|
|
|
switch (prop_id)
|
|
|
|
|
{
|
|
|
|
|
case PROP_BOOL:
|
|
|
|
|
test_object->bool_prop = g_value_get_boolean (value);
|
|
|
|
|
break;
|
2010-08-03 08:08:03 +02:00
|
|
|
|
case PROP_ANTI_BOOL:
|
|
|
|
|
test_object->anti_bool_prop = g_value_get_boolean (value);
|
|
|
|
|
break;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
case PROP_BYTE:
|
2011-09-22 22:08:35 +02:00
|
|
|
|
test_object->byte_prop = g_value_get_schar (value);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
break;
|
|
|
|
|
case PROP_INT16:
|
|
|
|
|
test_object->int16_prop = g_value_get_int (value);
|
|
|
|
|
break;
|
|
|
|
|
case PROP_UINT16:
|
|
|
|
|
test_object->uint16_prop = g_value_get_uint (value);
|
|
|
|
|
break;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
case PROP_INT:
|
|
|
|
|
test_object->int_prop = g_value_get_int (value);
|
|
|
|
|
break;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
case PROP_UINT:
|
|
|
|
|
test_object->uint_prop = g_value_get_uint (value);
|
|
|
|
|
break;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
case PROP_INT64:
|
|
|
|
|
test_object->int64_prop = g_value_get_int64 (value);
|
|
|
|
|
break;
|
|
|
|
|
case PROP_UINT64:
|
|
|
|
|
test_object->uint64_prop = g_value_get_uint64 (value);
|
|
|
|
|
break;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
case PROP_DOUBLE:
|
|
|
|
|
test_object->double_prop = g_value_get_double (value);
|
|
|
|
|
break;
|
|
|
|
|
case PROP_STRING:
|
|
|
|
|
g_free (test_object->string_prop);
|
|
|
|
|
test_object->string_prop = g_value_dup_string (value);
|
|
|
|
|
break;
|
2010-04-21 18:31:10 +02:00
|
|
|
|
case PROP_NO_READ:
|
|
|
|
|
g_free (test_object->no_read_prop);
|
|
|
|
|
test_object->no_read_prop = g_value_dup_string (value);
|
|
|
|
|
break;
|
2010-07-22 05:10:31 +02:00
|
|
|
|
case PROP_STRV:
|
|
|
|
|
g_strfreev (test_object->strv_prop);
|
|
|
|
|
test_object->strv_prop = g_value_dup_boxed (value);
|
|
|
|
|
break;
|
2010-07-05 18:08:17 +02:00
|
|
|
|
case PROP_ENUM:
|
|
|
|
|
test_object->enum_prop = g_value_get_enum (value);
|
|
|
|
|
break;
|
2012-08-19 08:24:04 +02:00
|
|
|
|
case PROP_FLAGS:
|
|
|
|
|
test_object->flags_prop = g_value_get_flags (value);
|
|
|
|
|
break;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
default:
|
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-05 18:08:17 +02:00
|
|
|
|
static GType
|
|
|
|
|
test_enum_get_type (void)
|
|
|
|
|
{
|
2023-09-12 10:26:21 +02:00
|
|
|
|
static GType define_type_id = 0;
|
2010-07-05 18:08:17 +02:00
|
|
|
|
|
2023-09-12 10:26:21 +02:00
|
|
|
|
if (g_once_init_enter_pointer (&define_type_id))
|
2010-07-05 18:08:17 +02:00
|
|
|
|
{
|
|
|
|
|
static const GEnumValue values[] = {
|
|
|
|
|
{ TEST_ENUM_FOO, "TEST_ENUM_FOO", "foo" },
|
|
|
|
|
{ TEST_ENUM_BAR, "TEST_ENUM_BAR", "bar" },
|
|
|
|
|
{ TEST_ENUM_BAZ, "TEST_ENUM_BAZ", "baz" },
|
|
|
|
|
{ TEST_ENUM_QUUX, "TEST_ENUM_QUUX", "quux" },
|
|
|
|
|
{ 0, NULL, NULL }
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
GType type_id = g_enum_register_static ("TestEnum", values);
|
2023-09-12 10:26:21 +02:00
|
|
|
|
g_once_init_leave_pointer (&define_type_id, type_id);
|
2010-07-05 18:08:17 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return define_type_id;
|
|
|
|
|
}
|
|
|
|
|
|
2012-08-19 08:24:04 +02:00
|
|
|
|
static GType
|
|
|
|
|
test_flags_get_type (void)
|
|
|
|
|
{
|
2023-09-12 10:26:21 +02:00
|
|
|
|
static GType define_type_id = 0;
|
2012-08-19 08:24:04 +02:00
|
|
|
|
|
2023-09-12 10:26:21 +02:00
|
|
|
|
if (g_once_init_enter_pointer (&define_type_id))
|
2012-08-19 08:24:04 +02:00
|
|
|
|
{
|
|
|
|
|
static const GFlagsValue values[] = {
|
|
|
|
|
{ TEST_FLAGS_NONE, "TEST_FLAGS_NONE", "none" },
|
|
|
|
|
{ TEST_FLAGS_MOURNING, "TEST_FLAGS_MOURNING", "mourning" },
|
|
|
|
|
{ TEST_FLAGS_LAUGHING, "TEST_FLAGS_LAUGHING", "laughing" },
|
|
|
|
|
{ TEST_FLAGS_WALKING, "TEST_FLAGS_WALKING", "walking" },
|
|
|
|
|
{ 0, NULL, NULL }
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
GType type_id = g_flags_register_static ("TestFlags", values);
|
2023-09-12 10:26:21 +02:00
|
|
|
|
g_once_init_leave_pointer (&define_type_id, type_id);
|
2012-08-19 08:24:04 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return define_type_id;
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_object_class_init (TestObjectClass *class)
|
|
|
|
|
{
|
|
|
|
|
GObjectClass *gobject_class = G_OBJECT_CLASS (class);
|
|
|
|
|
|
|
|
|
|
gobject_class->get_property = test_object_get_property;
|
|
|
|
|
gobject_class->set_property = test_object_set_property;
|
|
|
|
|
gobject_class->finalize = test_object_finalize;
|
|
|
|
|
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_BOOL,
|
|
|
|
|
g_param_spec_boolean ("bool", "", "", FALSE, G_PARAM_READWRITE));
|
2010-08-03 08:08:03 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_ANTI_BOOL,
|
|
|
|
|
g_param_spec_boolean ("anti-bool", "", "", FALSE, G_PARAM_READWRITE));
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_BYTE,
|
|
|
|
|
g_param_spec_char ("byte", "", "", G_MININT8, G_MAXINT8, 0, G_PARAM_READWRITE));
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_INT16,
|
|
|
|
|
g_param_spec_int ("int16", "", "", -G_MAXINT16, G_MAXINT16, 0, G_PARAM_READWRITE));
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_UINT16,
|
|
|
|
|
g_param_spec_uint ("uint16", "", "", 0, G_MAXUINT16, 0, G_PARAM_READWRITE));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_INT,
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_param_spec_int ("int", "", "", G_MININT, G_MAXINT, 0, G_PARAM_READWRITE));
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_UINT,
|
|
|
|
|
g_param_spec_uint ("uint", "", "", 0, G_MAXUINT, 0, G_PARAM_READWRITE));
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_INT64,
|
|
|
|
|
g_param_spec_int64 ("int64", "", "", G_MININT64, G_MAXINT64, 0, G_PARAM_READWRITE));
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_UINT64,
|
|
|
|
|
g_param_spec_uint64 ("uint64", "", "", 0, G_MAXUINT64, 0, G_PARAM_READWRITE));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_DOUBLE,
|
|
|
|
|
g_param_spec_double ("double", "", "", -G_MAXDOUBLE, G_MAXDOUBLE, 0.0, G_PARAM_READWRITE));
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_STRING,
|
|
|
|
|
g_param_spec_string ("string", "", "", NULL, G_PARAM_READWRITE));
|
2010-04-21 18:31:10 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_NO_WRITE,
|
|
|
|
|
g_param_spec_string ("no-write", "", "", NULL, G_PARAM_READABLE));
|
|
|
|
|
g_object_class_install_property (gobject_class, PROP_NO_READ,
|
|
|
|
|
g_param_spec_string ("no-read", "", "", NULL, G_PARAM_WRITABLE));
|
2010-07-22 05:10:31 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_STRV,
|
|
|
|
|
g_param_spec_boxed ("strv", "", "", G_TYPE_STRV, G_PARAM_READWRITE));
|
2010-07-05 18:08:17 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_ENUM,
|
|
|
|
|
g_param_spec_enum ("enum", "", "", test_enum_get_type (), TEST_ENUM_FOO, G_PARAM_READWRITE));
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_object_class_install_property (gobject_class, PROP_FLAGS,
|
|
|
|
|
g_param_spec_flags ("flags", "", "", test_flags_get_type (), TEST_FLAGS_NONE, G_PARAM_READWRITE));
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static TestObject *
|
|
|
|
|
test_object_new (void)
|
|
|
|
|
{
|
|
|
|
|
return (TestObject*)g_object_new (test_object_get_type (), NULL);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test basic binding functionality for simple types.
|
|
|
|
|
* Verify that with bidirectional bindings, changes on either side
|
|
|
|
|
* are notified on the other end.
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_simple_binding (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gboolean b;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
gchar y;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
gint i;
|
2012-04-08 16:20:46 +02:00
|
|
|
|
guint u;
|
2010-07-08 17:33:21 +02:00
|
|
|
|
gint16 n;
|
|
|
|
|
guint16 q;
|
2010-10-04 04:53:49 +02:00
|
|
|
|
gint n2;
|
|
|
|
|
guint q2;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
gint64 i64;
|
|
|
|
|
guint64 u64;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
gdouble d;
|
|
|
|
|
gchar *s;
|
2010-07-05 09:09:36 +02:00
|
|
|
|
GVariant *value;
|
2010-07-22 05:10:31 +02:00
|
|
|
|
gchar **strv;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "bool", obj, "bool", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
g_object_set (obj, "bool", TRUE, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_boolean (settings, "bool"), ==, TRUE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_boolean (settings, "bool", FALSE);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
b = TRUE;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
2010-08-03 08:08:03 +02:00
|
|
|
|
g_settings_bind (settings, "anti-bool", obj, "anti-bool",
|
|
|
|
|
G_SETTINGS_BIND_INVERT_BOOLEAN);
|
|
|
|
|
g_object_set (obj, "anti-bool", FALSE, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_boolean (settings, "anti-bool"), ==, TRUE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_boolean (settings, "anti-bool", FALSE);
|
|
|
|
|
b = FALSE;
|
|
|
|
|
g_object_get (obj, "anti-bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, TRUE);
|
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_settings_bind (settings, "byte", obj, "byte", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "byte", 123, NULL);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
y = 'c';
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_settings_get (settings, "byte", "y", &y);
|
|
|
|
|
g_assert_cmpint (y, ==, 123);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "byte", "y", 54);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
y = 'c';
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_object_get (obj, "byte", &y, NULL);
|
|
|
|
|
g_assert_cmpint (y, ==, 54);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "int16", obj, "int16", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int16", 1234, NULL);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
n = 4321;
|
|
|
|
|
g_settings_get (settings, "int16", "n", &n);
|
|
|
|
|
g_assert_cmpint (n, ==, 1234);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "int16", "n", 4321);
|
2010-10-04 04:53:49 +02:00
|
|
|
|
n2 = 1111;
|
|
|
|
|
g_object_get (obj, "int16", &n2, NULL);
|
|
|
|
|
g_assert_cmpint (n2, ==, 4321);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "uint16", obj, "uint16", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "uint16", (guint16) G_MAXUINT16, NULL);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
q = 1111;
|
|
|
|
|
g_settings_get (settings, "uint16", "q", &q);
|
|
|
|
|
g_assert_cmpuint (q, ==, G_MAXUINT16);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "uint16", "q", (guint16) G_MAXINT16);
|
2010-10-04 04:53:49 +02:00
|
|
|
|
q2 = 1111;
|
|
|
|
|
g_object_get (obj, "uint16", &q2, NULL);
|
|
|
|
|
g_assert_cmpuint (q2, ==, (guint16) G_MAXINT16);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_bind (settings, "int", obj, "int", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int", 12345, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "int"), ==, 12345);
|
|
|
|
|
|
|
|
|
|
g_settings_set_int (settings, "int", 54321);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
i = 1111;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_get (obj, "int", &i, NULL);
|
|
|
|
|
g_assert_cmpint (i, ==, 54321);
|
|
|
|
|
|
2012-04-08 16:20:46 +02:00
|
|
|
|
g_settings_bind (settings, "uint", obj, "uint", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "uint", 12345, NULL);
|
|
|
|
|
g_assert_cmpuint (g_settings_get_uint (settings, "uint"), ==, 12345);
|
|
|
|
|
|
|
|
|
|
g_settings_set_uint (settings, "uint", 54321);
|
|
|
|
|
u = 1111;
|
|
|
|
|
g_object_get (obj, "uint", &u, NULL);
|
|
|
|
|
g_assert_cmpuint (u, ==, 54321);
|
|
|
|
|
|
2015-09-21 13:02:45 +02:00
|
|
|
|
g_settings_bind (settings, "uint64", obj, "uint64", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
2016-06-23 17:47:30 +02:00
|
|
|
|
g_object_set (obj, "uint64", (guint64) 12345, NULL);
|
2015-09-21 13:02:45 +02:00
|
|
|
|
g_assert_cmpuint (g_settings_get_uint64 (settings, "uint64"), ==, 12345);
|
|
|
|
|
|
|
|
|
|
g_settings_set_uint64 (settings, "uint64", 54321);
|
2016-07-22 17:49:54 +02:00
|
|
|
|
u64 = 1111;
|
|
|
|
|
g_object_get (obj, "uint64", &u64, NULL);
|
|
|
|
|
g_assert_cmpuint (u64, ==, 54321);
|
2015-09-21 13:02:45 +02:00
|
|
|
|
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_settings_bind (settings, "int64", obj, "int64", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int64", (gint64) G_MAXINT64, NULL);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
i64 = 1111;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_settings_get (settings, "int64", "x", &i64);
|
|
|
|
|
g_assert_cmpint (i64, ==, G_MAXINT64);
|
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "int64", "x", (gint64) G_MININT64);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
i64 = 1111;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_object_get (obj, "int64", &i64, NULL);
|
2010-04-19 16:34:22 +02:00
|
|
|
|
g_assert_cmpint (i64, ==, G_MININT64);
|
2010-04-19 16:00:03 +02:00
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "uint64", obj, "uint64", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "uint64", (guint64) G_MAXUINT64, NULL);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
u64 = 1111;
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_settings_get (settings, "uint64", "t", &u64);
|
2010-04-21 01:39:03 +02:00
|
|
|
|
g_assert_cmpuint (u64, ==, G_MAXUINT64);
|
2010-04-19 16:00:03 +02:00
|
|
|
|
|
2010-04-19 16:34:22 +02:00
|
|
|
|
g_settings_set (settings, "uint64", "t", (guint64) G_MAXINT64);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
u64 = 1111;
|
2010-04-19 16:34:22 +02:00
|
|
|
|
g_object_get (obj, "uint64", &u64, NULL);
|
2010-04-21 01:39:03 +02:00
|
|
|
|
g_assert_cmpuint (u64, ==, (guint64) G_MAXINT64);
|
2010-04-19 16:00:03 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_bind (settings, "string", obj, "string", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "string", "bu ba", NULL);
|
|
|
|
|
s = g_settings_get_string (settings, "string");
|
|
|
|
|
g_assert_cmpstr (s, ==, "bu ba");
|
|
|
|
|
g_free (s);
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "bla bla");
|
|
|
|
|
g_object_get (obj, "string", &s, NULL);
|
|
|
|
|
g_assert_cmpstr (s, ==, "bla bla");
|
|
|
|
|
g_free (s);
|
|
|
|
|
|
2010-07-05 09:09:36 +02:00
|
|
|
|
g_settings_bind (settings, "chararray", obj, "string", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "string", "non-unicode:\315", NULL);
|
|
|
|
|
value = g_settings_get_value (settings, "chararray");
|
2010-07-07 16:37:16 +02:00
|
|
|
|
g_assert_cmpstr (g_variant_get_bytestring (value), ==, "non-unicode:\315");
|
2010-07-05 09:09:36 +02:00
|
|
|
|
g_variant_unref (value);
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_settings_bind (settings, "double", obj, "double", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_object_set (obj, "double", G_MAXFLOAT, NULL);
|
|
|
|
|
g_assert_cmpfloat (g_settings_get_double (settings, "double"), ==, G_MAXFLOAT);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_settings_set_double (settings, "double", G_MINFLOAT);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
d = 1.0;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_get (obj, "double", &d, NULL);
|
2010-04-19 16:00:03 +02:00
|
|
|
|
g_assert_cmpfloat (d, ==, G_MINFLOAT);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2010-04-19 16:34:22 +02:00
|
|
|
|
g_object_set (obj, "double", G_MAXDOUBLE, NULL);
|
|
|
|
|
g_assert_cmpfloat (g_settings_get_double (settings, "double"), ==, G_MAXDOUBLE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_double (settings, "double", -G_MINDOUBLE);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
d = 1.0;
|
2010-04-19 16:34:22 +02:00
|
|
|
|
g_object_get (obj, "double", &d, NULL);
|
|
|
|
|
g_assert_cmpfloat (d, ==, -G_MINDOUBLE);
|
2010-07-05 09:09:36 +02:00
|
|
|
|
|
2010-07-22 05:10:31 +02:00
|
|
|
|
strv = g_strsplit ("plastic bag,middle class,polyethylene", ",", 0);
|
|
|
|
|
g_settings_bind (settings, "strv", obj, "strv", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
g_object_set (obj, "strv", strv, NULL);
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
strv = g_settings_get_strv (settings, "strv");
|
|
|
|
|
s = g_strjoinv (",", strv);
|
|
|
|
|
g_assert_cmpstr (s, ==, "plastic bag,middle class,polyethylene");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_free (s);
|
|
|
|
|
strv = g_strsplit ("decaffeinate,unleaded,keep all surfaces clean", ",", 0);
|
|
|
|
|
g_settings_set_strv (settings, "strv", (const gchar **) strv);
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_object_get (obj, "strv", &strv, NULL);
|
|
|
|
|
s = g_strjoinv (",", strv);
|
|
|
|
|
g_assert_cmpstr (s, ==, "decaffeinate,unleaded,keep all surfaces clean");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_free (s);
|
2013-12-21 07:00:10 +01:00
|
|
|
|
g_settings_set_strv (settings, "strv", NULL);
|
|
|
|
|
g_object_get (obj, "strv", &strv, NULL);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (strv);
|
2013-12-21 07:00:10 +01:00
|
|
|
|
g_assert_cmpint (g_strv_length (strv), ==, 0);
|
|
|
|
|
g_strfreev (strv);
|
2010-07-22 05:10:31 +02:00
|
|
|
|
|
2010-07-05 18:08:17 +02:00
|
|
|
|
g_settings_bind (settings, "enum", obj, "enum", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
g_object_set (obj, "enum", TEST_ENUM_BAZ, NULL);
|
2010-07-22 17:49:30 +02:00
|
|
|
|
s = g_settings_get_string (settings, "enum");
|
|
|
|
|
g_assert_cmpstr (s, ==, "baz");
|
|
|
|
|
g_free (s);
|
2010-07-05 18:08:17 +02:00
|
|
|
|
g_assert_cmpint (g_settings_get_enum (settings, "enum"), ==, TEST_ENUM_BAZ);
|
|
|
|
|
|
|
|
|
|
g_settings_set_enum (settings, "enum", TEST_ENUM_QUUX);
|
2010-07-08 17:33:21 +02:00
|
|
|
|
i = 230;
|
2010-07-05 18:08:17 +02:00
|
|
|
|
g_object_get (obj, "enum", &i, NULL);
|
|
|
|
|
g_assert_cmpint (i, ==, TEST_ENUM_QUUX);
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "enum", "baz");
|
2010-07-08 17:33:21 +02:00
|
|
|
|
i = 230;
|
2010-07-05 18:08:17 +02:00
|
|
|
|
g_object_get (obj, "enum", &i, NULL);
|
|
|
|
|
g_assert_cmpint (i, ==, TEST_ENUM_BAZ);
|
|
|
|
|
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_settings_bind (settings, "flags", obj, "flags", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
g_object_set (obj, "flags", TEST_FLAGS_MOURNING, NULL);
|
|
|
|
|
strv = g_settings_get_strv (settings, "flags");
|
|
|
|
|
g_assert_cmpint (g_strv_length (strv), ==, 1);
|
|
|
|
|
g_assert_cmpstr (strv[0], ==, "mourning");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
|
|
|
|
|
g_assert_cmpint (g_settings_get_flags (settings, "flags"), ==, TEST_FLAGS_MOURNING);
|
|
|
|
|
|
|
|
|
|
g_settings_set_flags (settings, "flags", TEST_FLAGS_MOURNING | TEST_FLAGS_WALKING);
|
|
|
|
|
i = 230;
|
|
|
|
|
g_object_get (obj, "flags", &i, NULL);
|
|
|
|
|
g_assert_cmpint (i, ==, TEST_FLAGS_MOURNING | TEST_FLAGS_WALKING);
|
|
|
|
|
|
2018-03-29 13:29:21 +02:00
|
|
|
|
g_settings_bind (settings, "uint", obj, "uint", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "uint", 12345, NULL);
|
|
|
|
|
g_assert_cmpuint (g_settings_get_uint (settings, "uint"), ==, 12345);
|
|
|
|
|
|
|
|
|
|
g_settings_set_uint (settings, "uint", 54321);
|
|
|
|
|
u = 1111;
|
|
|
|
|
g_object_get (obj, "uint", &u, NULL);
|
|
|
|
|
g_assert_cmpuint (u, ==, 54321);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "range", obj, "uint", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
g_object_set (obj, "uint", 22, NULL);
|
|
|
|
|
u = 1111;
|
|
|
|
|
g_assert_cmpuint (g_settings_get_uint (settings, "range"), ==, 22);
|
|
|
|
|
g_object_get (obj, "uint", &u, NULL);
|
|
|
|
|
g_assert_cmpuint (u, ==, 22);
|
|
|
|
|
|
|
|
|
|
g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"* is out of schema-specified range for*");
|
|
|
|
|
g_object_set (obj, "uint", 45, NULL);
|
|
|
|
|
g_test_assert_expected_messages ();
|
|
|
|
|
u = 1111;
|
|
|
|
|
g_object_get (obj, "uint", &u, NULL);
|
|
|
|
|
g_assert_cmpuint (g_settings_get_uint (settings, "range"), ==, 22);
|
|
|
|
|
/* The value of the object is currently not reset back to its initial value
|
|
|
|
|
g_assert_cmpuint (u, ==, 22); */
|
|
|
|
|
|
2010-07-05 09:09:36 +02:00
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_unbind (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "int", obj, "int", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int", 12345, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "int"), ==, 12345);
|
|
|
|
|
|
|
|
|
|
g_settings_unbind (obj, "int");
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int", 54321, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "int"), ==, 12345);
|
|
|
|
|
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_bind_writable (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gboolean b;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "bool", FALSE, NULL);
|
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_settings_bind_writable (settings, "int", obj, "bool", FALSE);
|
2010-07-05 09:09:36 +02:00
|
|
|
|
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (b);
|
2010-07-05 09:09:36 +02:00
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_settings_unbind (obj, "bool");
|
|
|
|
|
|
|
|
|
|
g_settings_bind_writable (settings, "int", obj, "bool", TRUE);
|
|
|
|
|
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (b);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test one-way bindings.
|
|
|
|
|
* Verify that changes on one side show up on the other,
|
|
|
|
|
* but not vice versa
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_directional_binding (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gboolean b;
|
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "bool", FALSE, NULL);
|
|
|
|
|
g_settings_set_boolean (settings, "bool", FALSE);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "bool", obj, "bool", G_SETTINGS_BIND_GET);
|
|
|
|
|
|
|
|
|
|
g_settings_set_boolean (settings, "bool", TRUE);
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, TRUE);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "bool", FALSE, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_boolean (settings, "bool"), ==, TRUE);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int", 20, NULL);
|
|
|
|
|
g_settings_set_int (settings, "int", 20);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "int", obj, "int", G_SETTINGS_BIND_SET);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "int", 32, NULL);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "int"), ==, 32);
|
|
|
|
|
|
|
|
|
|
g_settings_set_int (settings, "int", 20);
|
|
|
|
|
g_object_get (obj, "int", &i, NULL);
|
|
|
|
|
g_assert_cmpint (i, ==, 32);
|
|
|
|
|
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2013-12-15 17:20:19 +01:00
|
|
|
|
/* Test that type mismatch is caught when creating a binding */
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_typesafe_binding (void)
|
|
|
|
|
{
|
|
|
|
|
if (!g_test_undefined ())
|
|
|
|
|
return;
|
|
|
|
|
|
2013-12-15 17:20:19 +01:00
|
|
|
|
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;
|
|
|
|
|
}
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess (NULL, 0, G_TEST_SUBPROCESS_DEFAULT);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*not compatible*");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static gboolean
|
|
|
|
|
string_to_bool (GValue *value,
|
|
|
|
|
GVariant *variant,
|
|
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
const gchar *s;
|
|
|
|
|
|
|
|
|
|
s = g_variant_get_string (variant, NULL);
|
|
|
|
|
g_value_set_boolean (value, g_strcmp0 (s, "true") == 0);
|
|
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GVariant *
|
|
|
|
|
bool_to_string (const GValue *value,
|
|
|
|
|
const GVariantType *expected_type,
|
|
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
if (g_value_get_boolean (value))
|
|
|
|
|
return g_variant_new_string ("true");
|
|
|
|
|
else
|
|
|
|
|
return g_variant_new_string ("false");
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-29 13:29:21 +02:00
|
|
|
|
static GVariant *
|
|
|
|
|
bool_to_bool (const GValue *value,
|
|
|
|
|
const GVariantType *expected_type,
|
|
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
return g_variant_new_boolean (g_value_get_boolean (value));
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test custom bindings.
|
|
|
|
|
* Translate strings to booleans and back
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_custom_binding (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *s;
|
|
|
|
|
gboolean b;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "true");
|
|
|
|
|
|
|
|
|
|
g_settings_bind_with_mapping (settings, "string",
|
|
|
|
|
obj, "bool",
|
|
|
|
|
G_SETTINGS_BIND_DEFAULT,
|
|
|
|
|
string_to_bool,
|
|
|
|
|
bool_to_string,
|
|
|
|
|
NULL, NULL);
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "false");
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "not true");
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "bool", TRUE, NULL);
|
|
|
|
|
s = g_settings_get_string (settings, "string");
|
|
|
|
|
g_assert_cmpstr (s, ==, "true");
|
2010-06-24 06:36:42 +02:00
|
|
|
|
g_free (s);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2018-03-29 13:29:21 +02:00
|
|
|
|
g_settings_bind_with_mapping (settings, "string",
|
|
|
|
|
obj, "bool",
|
|
|
|
|
G_SETTINGS_BIND_DEFAULT,
|
|
|
|
|
string_to_bool, bool_to_bool,
|
|
|
|
|
NULL, NULL);
|
|
|
|
|
g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"*binding mapping function for key 'string' returned"
|
|
|
|
|
" GVariant of type 'b' when type 's' was requested*");
|
|
|
|
|
g_object_set (obj, "bool", FALSE, NULL);
|
|
|
|
|
g_test_assert_expected_messages ();
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-18 05:15:46 +01:00
|
|
|
|
/* Same test as above, but with closures
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_bind_with_mapping_closures (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
char *s;
|
|
|
|
|
gboolean b;
|
|
|
|
|
GClosure *get;
|
|
|
|
|
GClosure *set;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "true");
|
|
|
|
|
|
|
|
|
|
get = g_cclosure_new (G_CALLBACK (string_to_bool), NULL, NULL);
|
|
|
|
|
set = g_cclosure_new (G_CALLBACK (bool_to_string), NULL, NULL);
|
|
|
|
|
|
|
|
|
|
g_settings_bind_with_mapping_closures (settings, "string",
|
|
|
|
|
G_OBJECT (obj), "bool",
|
|
|
|
|
G_SETTINGS_BIND_DEFAULT, get, set);
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "false");
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "not true");
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "bool", TRUE, NULL);
|
|
|
|
|
s = g_settings_get_string (settings, "string");
|
|
|
|
|
g_assert_cmpstr (s, ==, "true");
|
|
|
|
|
g_free (s);
|
|
|
|
|
|
|
|
|
|
set = g_cclosure_new (G_CALLBACK (bool_to_bool), NULL, NULL);
|
|
|
|
|
|
|
|
|
|
g_settings_bind_with_mapping_closures (settings, "string",
|
|
|
|
|
G_OBJECT (obj), "bool",
|
|
|
|
|
G_SETTINGS_BIND_DEFAULT, get, set);
|
|
|
|
|
g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL,
|
|
|
|
|
"*binding mapping function for key 'string' returned"
|
|
|
|
|
" GVariant of type 'b' when type 's' was requested*");
|
|
|
|
|
g_object_set (obj, "bool", FALSE, NULL);
|
|
|
|
|
g_test_assert_expected_messages ();
|
|
|
|
|
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
gboolean get_called;
|
|
|
|
|
gboolean set_called;
|
|
|
|
|
gboolean get_freed;
|
|
|
|
|
gboolean set_freed;
|
|
|
|
|
} BindWithMappingData;
|
|
|
|
|
|
|
|
|
|
static gboolean
|
|
|
|
|
get_callback (GValue *value,
|
|
|
|
|
GVariant *variant,
|
|
|
|
|
void *user_data)
|
|
|
|
|
{
|
|
|
|
|
BindWithMappingData *data = (BindWithMappingData *) user_data;
|
|
|
|
|
data->get_called = TRUE;
|
|
|
|
|
|
|
|
|
|
g_assert_true (G_VALUE_HOLDS_BOOLEAN (value));
|
|
|
|
|
g_assert_true (g_variant_is_of_type (variant, G_VARIANT_TYPE_STRING));
|
|
|
|
|
|
|
|
|
|
return string_to_bool (value, variant, NULL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GVariant *
|
|
|
|
|
set_callback (const GValue *value,
|
|
|
|
|
const GVariantType *expected_type,
|
|
|
|
|
void *user_data)
|
|
|
|
|
{
|
|
|
|
|
BindWithMappingData *data = (BindWithMappingData *) user_data;
|
|
|
|
|
data->set_called = TRUE;
|
|
|
|
|
|
|
|
|
|
g_assert_true (G_VALUE_HOLDS_BOOLEAN (value));
|
|
|
|
|
g_assert_true (g_variant_type_equal (expected_type, G_VARIANT_TYPE_STRING));
|
|
|
|
|
|
|
|
|
|
return bool_to_string (value, expected_type, NULL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
teardown_get (void *user_data, GClosure *closure)
|
|
|
|
|
{
|
|
|
|
|
BindWithMappingData *data = (BindWithMappingData *) user_data;
|
|
|
|
|
data->get_freed = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
teardown_set (void *user_data, GClosure *closure)
|
|
|
|
|
{
|
|
|
|
|
BindWithMappingData *data = (BindWithMappingData *) user_data;
|
|
|
|
|
data->set_freed = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Tests the types of GValue and GVariant passed to the closures */
|
|
|
|
|
static void
|
|
|
|
|
test_bind_with_mapping_closures_parameters (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GClosure *get;
|
|
|
|
|
GClosure *set;
|
|
|
|
|
BindWithMappingData data = { FALSE, FALSE, FALSE, FALSE };
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_settings_set_string (settings, "string", "true");
|
|
|
|
|
|
|
|
|
|
get = g_cclosure_new (G_CALLBACK (get_callback), &data, teardown_get);
|
|
|
|
|
set = g_cclosure_new (G_CALLBACK (set_callback), &data, teardown_set);
|
|
|
|
|
|
|
|
|
|
g_settings_bind_with_mapping_closures (settings, "string",
|
|
|
|
|
G_OBJECT (obj), "bool",
|
|
|
|
|
G_SETTINGS_BIND_DEFAULT, get, set);
|
|
|
|
|
|
|
|
|
|
g_assert_true (data.get_called);
|
|
|
|
|
g_assert_false (data.set_called);
|
|
|
|
|
|
|
|
|
|
data.get_called = FALSE;
|
|
|
|
|
g_object_set (obj, "bool", FALSE, NULL);
|
|
|
|
|
g_assert_true (data.set_called);
|
|
|
|
|
g_assert_false (data.get_called);
|
|
|
|
|
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
|
|
|
|
|
g_assert_true (data.get_freed);
|
|
|
|
|
g_assert_true (data.set_freed);
|
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 22:13:22 +02:00
|
|
|
|
/* Test that with G_SETTINGS_BIND_NO_CHANGES, the
|
|
|
|
|
* initial settings value is transported to the object
|
|
|
|
|
* side, but later settings changes do not affect the
|
|
|
|
|
* object
|
|
|
|
|
*/
|
2010-04-17 07:43:58 +02:00
|
|
|
|
static void
|
|
|
|
|
test_no_change_binding (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gboolean b;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_object_set (obj, "bool", TRUE, NULL);
|
|
|
|
|
g_settings_set_boolean (settings, "bool", FALSE);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "bool", obj, "bool", G_SETTINGS_BIND_GET_NO_CHANGES);
|
|
|
|
|
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_boolean (settings, "bool", TRUE);
|
|
|
|
|
g_object_get (obj, "bool", &b, NULL);
|
|
|
|
|
g_assert_cmpint (b, ==, FALSE);
|
|
|
|
|
|
|
|
|
|
g_settings_set_boolean (settings, "bool", FALSE);
|
|
|
|
|
g_object_set (obj, "bool", TRUE, NULL);
|
|
|
|
|
b = g_settings_get_boolean (settings, "bool");
|
|
|
|
|
g_assert_cmpint (b, ==, TRUE);
|
|
|
|
|
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-21 18:31:10 +02:00
|
|
|
|
/* Test that binding a non-readable property only
|
|
|
|
|
* works in 'GET' mode.
|
|
|
|
|
*/
|
2012-11-24 22:34:13 +01:00
|
|
|
|
static void
|
2012-11-24 21:58:36 +01:00
|
|
|
|
test_no_read_binding_fail (void)
|
2012-11-24 22:34:13 +01:00
|
|
|
|
{
|
2012-11-24 21:58:36 +01:00
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_settings_bind (settings, "string", obj, "no-read", 0);
|
|
|
|
|
}
|
2012-11-24 22:34:13 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_no_read_binding_pass (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_settings_bind (settings, "string", obj, "no-read", G_SETTINGS_BIND_GET);
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
exit (0);
|
|
|
|
|
}
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_no_read_binding (void)
|
|
|
|
|
{
|
|
|
|
|
if (g_test_undefined ())
|
|
|
|
|
{
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/no-read-binding/subprocess/fail", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*property*is not readable*");
|
2012-12-19 21:20:37 +01:00
|
|
|
|
}
|
2012-11-24 21:58:36 +01:00
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/no-read-binding/subprocess/pass", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-04-21 18:31:10 +02:00
|
|
|
|
g_test_trap_assert_passed ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Test that binding a non-writable property only
|
|
|
|
|
* works in 'SET' mode.
|
|
|
|
|
*/
|
2012-11-24 22:34:13 +01:00
|
|
|
|
static void
|
2012-11-24 21:58:36 +01:00
|
|
|
|
test_no_write_binding_fail (void)
|
2012-11-24 22:34:13 +01:00
|
|
|
|
{
|
2012-11-24 21:58:36 +01:00
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_settings_bind (settings, "string", obj, "no-write", 0);
|
|
|
|
|
}
|
2012-11-24 22:34:13 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_no_write_binding_pass (void)
|
|
|
|
|
{
|
|
|
|
|
TestObject *obj;
|
|
|
|
|
GSettings *settings;
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
settings = g_settings_new ("org.gtk.test.binding");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "string", obj, "no-write", G_SETTINGS_BIND_SET);
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
exit (0);
|
|
|
|
|
}
|
2012-12-19 21:20:37 +01:00
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_no_write_binding (void)
|
|
|
|
|
{
|
|
|
|
|
if (g_test_undefined ())
|
|
|
|
|
{
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/no-write-binding/subprocess/fail", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*property*is not writable*");
|
2012-12-19 21:20:37 +01:00
|
|
|
|
}
|
2012-11-24 21:58:36 +01:00
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/no-write-binding/subprocess/pass", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-04-21 18:31:10 +02:00
|
|
|
|
g_test_trap_assert_passed ();
|
|
|
|
|
}
|
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
static void
|
|
|
|
|
key_changed_cb (GSettings *settings, const gchar *key, gpointer data)
|
|
|
|
|
{
|
|
|
|
|
gboolean *b = data;
|
|
|
|
|
(*b) = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-10 22:21:36 +01:00
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
const gchar *path;
|
|
|
|
|
const gchar *root_group;
|
|
|
|
|
const gchar *keyfile_group;
|
|
|
|
|
const gchar *root_path;
|
|
|
|
|
} KeyfileTestData;
|
|
|
|
|
|
2010-04-18 03:19:45 +02:00
|
|
|
|
/*
|
|
|
|
|
* Test that using a keyfile works
|
|
|
|
|
*/
|
|
|
|
|
static void
|
2019-03-04 13:27:28 +01:00
|
|
|
|
test_keyfile (Fixture *fixture,
|
|
|
|
|
gconstpointer user_data)
|
2010-04-18 03:19:45 +02:00
|
|
|
|
{
|
2010-06-17 20:05:40 +02:00
|
|
|
|
GSettingsBackend *kf_backend;
|
2010-04-18 03:19:45 +02:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
GKeyFile *keyfile;
|
|
|
|
|
gchar *str;
|
2013-06-03 02:00:21 +02:00
|
|
|
|
gboolean writable;
|
|
|
|
|
GError *error = NULL;
|
|
|
|
|
gchar *data;
|
|
|
|
|
gsize len;
|
|
|
|
|
gboolean called = FALSE;
|
2019-03-04 13:27:28 +01:00
|
|
|
|
gchar *keyfile_path = NULL, *store_path = NULL;
|
2010-04-18 03:19:45 +02:00
|
|
|
|
|
2019-03-04 13:27:28 +01:00
|
|
|
|
keyfile_path = g_build_filename (fixture->tmp_dir, "keyfile", NULL);
|
|
|
|
|
store_path = g_build_filename (keyfile_path, "gsettings.store", NULL);
|
|
|
|
|
kf_backend = g_keyfile_settings_backend_new (store_path, "/", "root");
|
2010-06-17 20:05:40 +02:00
|
|
|
|
settings = g_settings_new_with_backend ("org.gtk.test", kf_backend);
|
|
|
|
|
g_object_unref (kf_backend);
|
2010-04-18 03:19:45 +02:00
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_settings_reset (settings, "greeting");
|
|
|
|
|
str = g_settings_get_string (settings, "greeting");
|
|
|
|
|
g_assert_cmpstr (str, ==, "Hello, earthlings");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
writable = g_settings_is_writable (settings, "greeting");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (writable);
|
2010-04-18 03:19:45 +02:00
|
|
|
|
g_settings_set (settings, "greeting", "s", "see if this works");
|
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
str = g_settings_get_string (settings, "greeting");
|
|
|
|
|
g_assert_cmpstr (str, ==, "see if this works");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
g_settings_delay (settings);
|
|
|
|
|
g_settings_set (settings, "farewell", "s", "cheerio");
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
|
2010-04-18 03:19:45 +02:00
|
|
|
|
keyfile = g_key_file_new ();
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_assert_true (g_key_file_load_from_file (keyfile, store_path, 0, NULL));
|
2010-04-18 03:19:45 +02:00
|
|
|
|
|
2010-06-22 14:12:04 +02:00
|
|
|
|
str = g_key_file_get_string (keyfile, "tests", "greeting", NULL);
|
2010-04-18 03:19:45 +02:00
|
|
|
|
g_assert_cmpstr (str, ==, "'see if this works'");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_free (str);
|
2010-04-18 03:19:45 +02:00
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
str = g_key_file_get_string (keyfile, "tests", "farewell", NULL);
|
|
|
|
|
g_assert_cmpstr (str, ==, "'cheerio'");
|
2010-04-18 03:19:45 +02:00
|
|
|
|
g_free (str);
|
2013-12-21 22:49:52 +01:00
|
|
|
|
g_key_file_free (keyfile);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2013-12-21 22:49:52 +01:00
|
|
|
|
g_settings_reset (settings, "greeting");
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
keyfile = g_key_file_new ();
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_assert_true (g_key_file_load_from_file (keyfile, store_path, 0, NULL));
|
2013-12-21 22:49:52 +01:00
|
|
|
|
|
|
|
|
|
str = g_key_file_get_string (keyfile, "tests", "greeting", NULL);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (str);
|
2013-12-21 22:49:52 +01:00
|
|
|
|
|
|
|
|
|
called = FALSE;
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_signal_connect (settings, "changed::greeting", G_CALLBACK (key_changed_cb), &called);
|
|
|
|
|
|
2013-12-22 06:44:56 +01:00
|
|
|
|
g_key_file_set_string (keyfile, "tests", "greeting", "'howdy'");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
data = g_key_file_to_data (keyfile, &len, NULL);
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_file_set_contents (store_path, data, len, &error);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_assert_no_error (error);
|
|
|
|
|
while (!called)
|
|
|
|
|
g_main_context_iteration (NULL, FALSE);
|
2013-12-22 06:44:56 +01:00
|
|
|
|
g_signal_handlers_disconnect_by_func (settings, key_changed_cb, &called);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2013-12-22 06:44:56 +01:00
|
|
|
|
str = g_settings_get_string (settings, "greeting");
|
|
|
|
|
g_assert_cmpstr (str, ==, "howdy");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2019-01-22 04:55:45 +01:00
|
|
|
|
/* Now check setting a string without quotes */
|
|
|
|
|
called = FALSE;
|
|
|
|
|
g_signal_connect (settings, "changed::greeting", G_CALLBACK (key_changed_cb), &called);
|
|
|
|
|
|
|
|
|
|
g_key_file_set_string (keyfile, "tests", "greeting", "he\"l🤗uń");
|
|
|
|
|
g_free (data);
|
|
|
|
|
data = g_key_file_to_data (keyfile, &len, NULL);
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_file_set_contents (store_path, data, len, &error);
|
2019-01-22 04:55:45 +01:00
|
|
|
|
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, ==, "he\"l🤗uń");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2013-12-22 06:44:56 +01:00
|
|
|
|
g_settings_set (settings, "farewell", "s", "cheerio");
|
2021-02-10 22:21:36 +01:00
|
|
|
|
|
|
|
|
|
/* Check that empty keys/groups are not allowed. */
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, ""));
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, "/"));
|
|
|
|
|
|
2014-05-11 23:38:27 +02:00
|
|
|
|
/* When executing as root, changing the mode of the keyfile will have
|
|
|
|
|
* no effect on the writability of the settings.
|
|
|
|
|
*/
|
|
|
|
|
if (geteuid () != 0)
|
|
|
|
|
{
|
|
|
|
|
called = FALSE;
|
|
|
|
|
g_signal_connect (settings, "writable-changed::greeting",
|
|
|
|
|
G_CALLBACK (key_changed_cb), &called);
|
2013-12-21 22:49:52 +01:00
|
|
|
|
|
2020-10-31 13:24:59 +01:00
|
|
|
|
g_assert_no_errno (g_chmod (keyfile_path, 0500));
|
2014-05-11 23:38:27 +02:00
|
|
|
|
while (!called)
|
|
|
|
|
g_main_context_iteration (NULL, FALSE);
|
|
|
|
|
g_signal_handlers_disconnect_by_func (settings, key_changed_cb, &called);
|
2013-12-22 06:44:56 +01:00
|
|
|
|
|
2014-05-11 23:38:27 +02:00
|
|
|
|
writable = g_settings_is_writable (settings, "greeting");
|
|
|
|
|
g_assert_false (writable);
|
|
|
|
|
}
|
2013-12-21 22:49:52 +01:00
|
|
|
|
|
2010-04-18 03:19:45 +02:00
|
|
|
|
g_key_file_free (keyfile);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_free (data);
|
|
|
|
|
|
2010-04-18 03:19:45 +02:00
|
|
|
|
g_object_unref (settings);
|
2019-03-04 13:27:28 +01:00
|
|
|
|
|
|
|
|
|
/* Clean up the temporary directory. */
|
2020-10-31 13:24:59 +01:00
|
|
|
|
g_assert_no_errno (g_chmod (keyfile_path, 0777));
|
2020-10-31 13:24:22 +01:00
|
|
|
|
g_assert_no_errno (g_remove (store_path));
|
2020-10-31 13:26:01 +01:00
|
|
|
|
g_assert_no_errno (g_rmdir (keyfile_path));
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_free (store_path);
|
|
|
|
|
g_free (keyfile_path);
|
2010-04-18 03:19:45 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-10 22:21:36 +01:00
|
|
|
|
/*
|
|
|
|
|
* Test that using a keyfile works with a schema with no path set.
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_keyfile_no_path (Fixture *fixture,
|
|
|
|
|
gconstpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
const KeyfileTestData *test_data = user_data;
|
|
|
|
|
GSettingsBackend *kf_backend;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GKeyFile *keyfile;
|
|
|
|
|
gboolean writable;
|
|
|
|
|
gchar *key = NULL;
|
|
|
|
|
GError *error = NULL;
|
|
|
|
|
gchar *keyfile_path = NULL, *store_path = NULL;
|
|
|
|
|
|
|
|
|
|
keyfile_path = g_build_filename (fixture->tmp_dir, "keyfile", NULL);
|
|
|
|
|
store_path = g_build_filename (keyfile_path, "gsettings.store", NULL);
|
|
|
|
|
kf_backend = g_keyfile_settings_backend_new (store_path, test_data->root_path, test_data->root_group);
|
|
|
|
|
settings = g_settings_new_with_backend_and_path ("org.gtk.test.no-path", kf_backend, test_data->path);
|
|
|
|
|
g_object_unref (kf_backend);
|
|
|
|
|
|
|
|
|
|
g_settings_reset (settings, "test-boolean");
|
|
|
|
|
g_assert_true (g_settings_get_boolean (settings, "test-boolean"));
|
|
|
|
|
|
|
|
|
|
writable = g_settings_is_writable (settings, "test-boolean");
|
|
|
|
|
g_assert_true (writable);
|
|
|
|
|
g_settings_set (settings, "test-boolean", "b", FALSE);
|
|
|
|
|
|
|
|
|
|
g_assert_false (g_settings_get_boolean (settings, "test-boolean"));
|
|
|
|
|
|
|
|
|
|
g_settings_delay (settings);
|
|
|
|
|
g_settings_set (settings, "test-boolean", "b", TRUE);
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
|
|
|
|
|
keyfile = g_key_file_new ();
|
|
|
|
|
g_assert_true (g_key_file_load_from_file (keyfile, store_path, 0, NULL));
|
|
|
|
|
|
|
|
|
|
g_assert_true (g_key_file_get_boolean (keyfile, test_data->keyfile_group, "test-boolean", NULL));
|
|
|
|
|
|
|
|
|
|
g_key_file_free (keyfile);
|
|
|
|
|
|
|
|
|
|
g_settings_reset (settings, "test-boolean");
|
|
|
|
|
g_settings_apply (settings);
|
|
|
|
|
keyfile = g_key_file_new ();
|
|
|
|
|
g_assert_true (g_key_file_load_from_file (keyfile, store_path, 0, NULL));
|
|
|
|
|
|
|
|
|
|
g_assert_false (g_key_file_get_string (keyfile, test_data->keyfile_group, "test-boolean", &error));
|
|
|
|
|
g_assert_error (error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_KEY_NOT_FOUND);
|
|
|
|
|
g_clear_error (&error);
|
|
|
|
|
|
|
|
|
|
/* Check that empty keys/groups are not allowed. */
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, ""));
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, "/"));
|
|
|
|
|
|
|
|
|
|
/* Keys which ghost the root group name are not allowed. This can only be
|
|
|
|
|
* tested when the path is `/` as otherwise it acts as a prefix and prevents
|
|
|
|
|
* any ghosting. */
|
|
|
|
|
if (g_str_equal (test_data->path, "/"))
|
|
|
|
|
{
|
|
|
|
|
key = g_strdup_printf ("%s/%s", test_data->root_group, "");
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, key));
|
|
|
|
|
g_free (key);
|
|
|
|
|
|
|
|
|
|
key = g_strdup_printf ("%s/%s", test_data->root_group, "/");
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, key));
|
|
|
|
|
g_free (key);
|
|
|
|
|
|
|
|
|
|
key = g_strdup_printf ("%s/%s", test_data->root_group, "test-boolean");
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, key));
|
|
|
|
|
g_free (key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
g_key_file_free (keyfile);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
/* Clean up the temporary directory. */
|
|
|
|
|
g_assert_no_errno (g_chmod (keyfile_path, 0777));
|
|
|
|
|
g_assert_no_errno (g_remove (store_path));
|
|
|
|
|
g_assert_no_errno (g_rmdir (keyfile_path));
|
|
|
|
|
g_free (store_path);
|
|
|
|
|
g_free (keyfile_path);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Test that a keyfile rejects writes to keys outside its root path.
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_keyfile_outside_root_path (Fixture *fixture,
|
|
|
|
|
gconstpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
GSettingsBackend *kf_backend;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *keyfile_path = NULL, *store_path = NULL;
|
|
|
|
|
|
|
|
|
|
keyfile_path = g_build_filename (fixture->tmp_dir, "keyfile", NULL);
|
|
|
|
|
store_path = g_build_filename (keyfile_path, "gsettings.store", NULL);
|
|
|
|
|
kf_backend = g_keyfile_settings_backend_new (store_path, "/tests/basic-types/", "root");
|
|
|
|
|
settings = g_settings_new_with_backend_and_path ("org.gtk.test.no-path", kf_backend, "/tests/");
|
|
|
|
|
g_object_unref (kf_backend);
|
|
|
|
|
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, "test-boolean"));
|
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
/* Clean up the temporary directory. The keyfile probably doesn’t exist, so
|
|
|
|
|
* don’t error on failure. */
|
|
|
|
|
g_remove (store_path);
|
|
|
|
|
g_assert_no_errno (g_rmdir (keyfile_path));
|
|
|
|
|
g_free (store_path);
|
|
|
|
|
g_free (keyfile_path);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Test that a keyfile rejects writes to keys in the root if no root group is set.
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_keyfile_no_root_group (Fixture *fixture,
|
|
|
|
|
gconstpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
GSettingsBackend *kf_backend;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *keyfile_path = NULL, *store_path = NULL;
|
|
|
|
|
|
|
|
|
|
keyfile_path = g_build_filename (fixture->tmp_dir, "keyfile", NULL);
|
|
|
|
|
store_path = g_build_filename (keyfile_path, "gsettings.store", NULL);
|
|
|
|
|
kf_backend = g_keyfile_settings_backend_new (store_path, "/", NULL);
|
|
|
|
|
settings = g_settings_new_with_backend_and_path ("org.gtk.test.no-path", kf_backend, "/");
|
|
|
|
|
g_object_unref (kf_backend);
|
|
|
|
|
|
|
|
|
|
g_assert_false (g_settings_is_writable (settings, "test-boolean"));
|
|
|
|
|
g_assert_true (g_settings_is_writable (settings, "child/test-boolean"));
|
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
/* Clean up the temporary directory. The keyfile probably doesn’t exist, so
|
|
|
|
|
* don’t error on failure. */
|
|
|
|
|
g_remove (store_path);
|
|
|
|
|
g_assert_no_errno (g_rmdir (keyfile_path));
|
|
|
|
|
g_free (store_path);
|
|
|
|
|
g_free (keyfile_path);
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-22 03:03:53 +02:00
|
|
|
|
/* Test that getting child schemas works
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_child_schema (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GSettings *child;
|
|
|
|
|
guint8 byte;
|
|
|
|
|
|
|
|
|
|
/* first establish some known conditions */
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.basic-types");
|
|
|
|
|
g_settings_set (settings, "test-byte", "y", 36);
|
|
|
|
|
|
|
|
|
|
g_settings_get (settings, "test-byte", "y", &byte);
|
|
|
|
|
g_assert_cmpint (byte, ==, 36);
|
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
child = g_settings_get_child (settings, "basic-types");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (child);
|
2010-04-22 03:03:53 +02:00
|
|
|
|
|
|
|
|
|
g_settings_get (child, "test-byte", "y", &byte);
|
|
|
|
|
g_assert_cmpint (byte, ==, 36);
|
|
|
|
|
|
|
|
|
|
g_object_unref (child);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
#include "../strinfo.c"
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_strinfo (void)
|
|
|
|
|
{
|
|
|
|
|
/* "foo" has a value of 1
|
|
|
|
|
* "bar" has a value of 2
|
|
|
|
|
* "baz" is an alias for "bar"
|
|
|
|
|
*/
|
|
|
|
|
gchar array[] =
|
|
|
|
|
"\1\0\0\0" "\xff""foo" "\0\0\0\xff" "\2\0\0\0"
|
|
|
|
|
"\xff" "bar" "\0\0\0\xff" "\3\0\0\0" "\xfe""baz"
|
|
|
|
|
"\0\0\0\xff";
|
|
|
|
|
const guint32 *strinfo = (guint32 *) array;
|
|
|
|
|
guint length = sizeof array / 4;
|
2019-02-18 10:50:26 +01:00
|
|
|
|
guint result = 0;
|
2010-06-14 23:29:41 +02:00
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
/* build it and compare */
|
|
|
|
|
GString *builder;
|
|
|
|
|
|
|
|
|
|
builder = g_string_new (NULL);
|
|
|
|
|
strinfo_builder_append_item (builder, "foo", 1);
|
|
|
|
|
strinfo_builder_append_item (builder, "bar", 2);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (strinfo_builder_append_alias (builder, "baz", "bar"));
|
2014-12-03 11:57:29 +01:00
|
|
|
|
g_assert_cmpmem (builder->str, builder->len, strinfo, length * 4);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_string_free (builder, TRUE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_alias (strinfo, length, "foo"),
|
|
|
|
|
==, NULL);
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_alias (strinfo, length, "bar"),
|
|
|
|
|
==, NULL);
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_alias (strinfo, length, "baz"),
|
|
|
|
|
==, "bar");
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_alias (strinfo, length, "quux"),
|
|
|
|
|
==, NULL);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (strinfo_enum_from_string (strinfo, length, "foo", &result));
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_assert_cmpint (result, ==, 1);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (strinfo_enum_from_string (strinfo, length, "bar", &result));
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_assert_cmpint (result, ==, 2);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (strinfo_enum_from_string (strinfo, length, "baz", &result));
|
|
|
|
|
g_assert_false (strinfo_enum_from_string (strinfo, length, "quux", &result));
|
2010-06-14 23:29:41 +02:00
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_enum (strinfo, length, 0), ==, NULL);
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_enum (strinfo, length, 1), ==, "foo");
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_enum (strinfo, length, 2), ==, "bar");
|
|
|
|
|
g_assert_cmpstr (strinfo_string_from_enum (strinfo, length, 3), ==, NULL);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (strinfo_is_string_valid (strinfo, length, "foo"));
|
|
|
|
|
g_assert_true (strinfo_is_string_valid (strinfo, length, "bar"));
|
|
|
|
|
g_assert_false (strinfo_is_string_valid (strinfo, length, "baz"));
|
|
|
|
|
g_assert_false (strinfo_is_string_valid (strinfo, length, "quux"));
|
2010-06-14 23:29:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_enums_non_enum_key (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *direct;
|
|
|
|
|
|
|
|
|
|
direct = g_settings_new ("org.gtk.test.enums.direct");
|
|
|
|
|
g_settings_get_enum (direct, "test");
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_enums_non_enum_value (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
g_settings_set_enum (settings, "test", 42);
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_enums_range (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
g_settings_set_string (settings, "test", "qux");
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_enums_non_flags (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
g_settings_get_flags (settings, "test");
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
static void
|
|
|
|
|
test_enums (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings, *direct;
|
2010-06-24 06:36:42 +02:00
|
|
|
|
gchar *str;
|
2010-06-14 23:29:41 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
direct = g_settings_new ("org.gtk.test.enums.direct");
|
|
|
|
|
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (g_test_undefined () && !backend_set)
|
2010-06-14 23:29:41 +02:00
|
|
|
|
{
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/enums/subprocess/non-enum-key", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*not associated with an enum*");
|
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/enums/subprocess/non-enum-value", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*invalid enum value 42*");
|
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/enums/subprocess/range", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
2010-11-07 18:56:08 +01:00
|
|
|
|
g_test_trap_assert_stderr ("*g_settings_set_value*valid range*");
|
2010-07-02 00:58:56 +02:00
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/enums/subprocess/non-flags", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*not associated with a flags*");
|
2010-06-14 23:29:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-06-24 06:36:42 +02:00
|
|
|
|
str = g_settings_get_string (settings, "test");
|
|
|
|
|
g_assert_cmpstr (str, ==, "bar");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_settings_set_enum (settings, "test", TEST_ENUM_FOO);
|
2010-06-24 06:36:42 +02:00
|
|
|
|
|
|
|
|
|
str = g_settings_get_string (settings, "test");
|
|
|
|
|
g_assert_cmpstr (str, ==, "foo");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_assert_cmpint (g_settings_get_enum (settings, "test"), ==, TEST_ENUM_FOO);
|
2010-06-24 06:36:42 +02:00
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_settings_set_string (direct, "test", "qux");
|
2010-06-24 06:36:42 +02:00
|
|
|
|
|
|
|
|
|
str = g_settings_get_string (direct, "test");
|
|
|
|
|
g_assert_cmpstr (str, ==, "qux");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
str = g_settings_get_string (settings, "test");
|
|
|
|
|
g_assert_cmpstr (str, ==, "quux");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_assert_cmpint (g_settings_get_enum (settings, "test"), ==, TEST_ENUM_QUUX);
|
2016-07-08 11:04:37 +02:00
|
|
|
|
|
|
|
|
|
g_object_unref (direct);
|
|
|
|
|
g_object_unref (settings);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_flags_non_flags_key (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *direct;
|
|
|
|
|
|
|
|
|
|
direct = g_settings_new ("org.gtk.test.enums.direct");
|
|
|
|
|
g_settings_get_flags (direct, "test");
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_flags_non_flags_value (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
g_settings_set_flags (settings, "f-test", 0x42);
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_flags_range (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
g_settings_set_strv (settings, "f-test",
|
|
|
|
|
(const gchar **) g_strsplit ("rock", ",", 0));
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_flags_non_enum (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
g_settings_get_enum (settings, "f-test");
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-02 00:58:56 +02:00
|
|
|
|
static void
|
|
|
|
|
test_flags (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings, *direct;
|
|
|
|
|
gchar **strv;
|
|
|
|
|
gchar *str;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
direct = g_settings_new ("org.gtk.test.enums.direct");
|
|
|
|
|
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (g_test_undefined () && !backend_set)
|
2010-07-02 00:58:56 +02:00
|
|
|
|
{
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/flags/subprocess/non-flags-key", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*not associated with a flags*");
|
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/flags/subprocess/non-flags-value", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*invalid flags value 0x00000042*");
|
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/flags/subprocess/range", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
2010-11-07 18:56:08 +01:00
|
|
|
|
g_test_trap_assert_stderr ("*g_settings_set_value*valid range*");
|
2010-07-02 00:58:56 +02:00
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/flags/subprocess/non-enum", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
|
|
|
|
g_test_trap_assert_stderr ("*not associated with an enum*");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
strv = g_settings_get_strv (settings, "f-test");
|
|
|
|
|
str = g_strjoinv (",", strv);
|
|
|
|
|
g_assert_cmpstr (str, ==, "");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
g_settings_set_flags (settings, "f-test",
|
|
|
|
|
TEST_FLAGS_WALKING | TEST_FLAGS_TALKING);
|
|
|
|
|
|
|
|
|
|
strv = g_settings_get_strv (settings, "f-test");
|
|
|
|
|
str = g_strjoinv (",", strv);
|
|
|
|
|
g_assert_cmpstr (str, ==, "talking,walking");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
g_assert_cmpint (g_settings_get_flags (settings, "f-test"), ==,
|
|
|
|
|
TEST_FLAGS_WALKING | TEST_FLAGS_TALKING);
|
|
|
|
|
|
|
|
|
|
strv = g_strsplit ("speaking,laughing", ",", 0);
|
|
|
|
|
g_settings_set_strv (direct, "f-test", (const gchar **) strv);
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
|
|
|
|
|
strv = g_settings_get_strv (direct, "f-test");
|
|
|
|
|
str = g_strjoinv (",", strv);
|
|
|
|
|
g_assert_cmpstr (str, ==, "speaking,laughing");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
strv = g_settings_get_strv (settings, "f-test");
|
|
|
|
|
str = g_strjoinv (",", strv);
|
|
|
|
|
g_assert_cmpstr (str, ==, "talking,laughing");
|
|
|
|
|
g_strfreev (strv);
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
g_assert_cmpint (g_settings_get_flags (settings, "f-test"), ==,
|
|
|
|
|
TEST_FLAGS_TALKING | TEST_FLAGS_LAUGHING);
|
2016-07-08 11:04:37 +02:00
|
|
|
|
|
|
|
|
|
g_object_unref (direct);
|
|
|
|
|
g_object_unref (settings);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
}
|
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
static void
|
|
|
|
|
test_range_high (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.range");
|
|
|
|
|
g_settings_set_int (settings, "val", 45);
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_range_low (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.range");
|
|
|
|
|
g_settings_set_int (settings, "val", 1);
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-14 23:29:41 +02:00
|
|
|
|
static void
|
|
|
|
|
test_range (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings, *direct;
|
2012-08-19 08:24:04 +02:00
|
|
|
|
GVariant *value;
|
2010-06-14 23:29:41 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.range");
|
|
|
|
|
direct = g_settings_new ("org.gtk.test.range.direct");
|
|
|
|
|
|
2011-12-14 19:08:59 +01:00
|
|
|
|
if (g_test_undefined () && !backend_set)
|
2010-06-14 23:29:41 +02:00
|
|
|
|
{
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/range/subprocess/high", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
2010-11-07 18:56:08 +01:00
|
|
|
|
g_test_trap_assert_stderr ("*g_settings_set_value*valid range*");
|
2010-06-14 23:29:41 +02:00
|
|
|
|
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/range/subprocess/low", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_trap_assert_failed ();
|
2010-11-07 18:56:08 +01:00
|
|
|
|
g_test_trap_assert_stderr ("*g_settings_set_value*valid range*");
|
2010-06-14 23:29:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 33);
|
|
|
|
|
g_settings_set_int (direct, "val", 22);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (direct, "val"), ==, 22);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 22);
|
|
|
|
|
g_settings_set_int (direct, "val", 45);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (direct, "val"), ==, 45);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 33);
|
|
|
|
|
g_settings_set_int (direct, "val", 1);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (direct, "val"), ==, 1);
|
|
|
|
|
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 33);
|
2012-08-19 08:24:04 +02:00
|
|
|
|
|
2013-12-21 18:51:22 +01:00
|
|
|
|
G_GNUC_BEGIN_IGNORE_DEPRECATIONS
|
2012-08-19 08:24:04 +02:00
|
|
|
|
value = g_variant_new_int32 (1);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (g_settings_range_check (settings, "val", value));
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_variant_unref (value);
|
|
|
|
|
value = g_variant_new_int32 (33);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_settings_range_check (settings, "val", value));
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_variant_unref (value);
|
|
|
|
|
value = g_variant_new_int32 (45);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (g_settings_range_check (settings, "val", value));
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_variant_unref (value);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
G_GNUC_END_IGNORE_DEPRECATIONS
|
2016-07-08 11:04:37 +02:00
|
|
|
|
|
|
|
|
|
g_object_unref (direct);
|
|
|
|
|
g_object_unref (settings);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
static gboolean
|
2022-03-17 17:24:49 +01:00
|
|
|
|
strv_set_equal (const gchar * const *strv, ...)
|
2010-07-05 21:53:58 +02:00
|
|
|
|
{
|
2020-11-20 19:24:47 +01:00
|
|
|
|
gsize count;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
va_list list;
|
|
|
|
|
const gchar *str;
|
|
|
|
|
gboolean res;
|
|
|
|
|
|
|
|
|
|
res = TRUE;
|
|
|
|
|
count = 0;
|
|
|
|
|
va_start (list, strv);
|
|
|
|
|
while (1)
|
|
|
|
|
{
|
|
|
|
|
str = va_arg (list, const gchar *);
|
|
|
|
|
if (str == NULL)
|
|
|
|
|
break;
|
2022-03-17 17:24:49 +01:00
|
|
|
|
if (!g_strv_contains (strv, str))
|
2010-07-05 21:53:58 +02:00
|
|
|
|
{
|
|
|
|
|
res = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
count++;
|
|
|
|
|
}
|
|
|
|
|
va_end (list);
|
|
|
|
|
|
|
|
|
|
if (res)
|
|
|
|
|
res = g_strv_length ((gchar**)strv) == count;
|
|
|
|
|
|
|
|
|
|
return res;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_list_items (void)
|
|
|
|
|
{
|
2014-11-19 18:45:06 +01:00
|
|
|
|
GSettingsSchema *schema;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
GSettings *settings;
|
2010-09-06 18:47:37 +02:00
|
|
|
|
gchar **children;
|
|
|
|
|
gchar **keys;
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
2014-11-19 18:45:06 +01:00
|
|
|
|
g_object_get (settings, "settings-schema", &schema, NULL);
|
2010-09-06 18:47:37 +02:00
|
|
|
|
children = g_settings_list_children (settings);
|
2014-11-19 18:45:06 +01:00
|
|
|
|
keys = g_settings_schema_list_keys (schema);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
2022-03-17 17:24:49 +01:00
|
|
|
|
g_assert_true (strv_set_equal ((const gchar * const *) children, "basic-types", "complex-types", "localized", NULL));
|
|
|
|
|
g_assert_true (strv_set_equal ((const gchar * const *) keys, "greeting", "farewell", NULL));
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
2010-09-06 18:47:37 +02:00
|
|
|
|
g_strfreev (children);
|
|
|
|
|
g_strfreev (keys);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
|
2014-11-19 18:45:06 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-27 07:00:55 +02:00
|
|
|
|
static void
|
|
|
|
|
test_list_schemas (void)
|
|
|
|
|
{
|
|
|
|
|
const gchar * const *schemas;
|
2010-10-03 04:42:02 +02:00
|
|
|
|
const gchar * const *relocs;
|
2010-07-27 07:00:55 +02:00
|
|
|
|
|
2013-12-21 18:51:22 +01:00
|
|
|
|
G_GNUC_BEGIN_IGNORE_DEPRECATIONS
|
2010-10-03 04:42:02 +02:00
|
|
|
|
relocs = g_settings_list_relocatable_schemas ();
|
2010-07-27 07:00:55 +02:00
|
|
|
|
schemas = g_settings_list_schemas ();
|
2013-12-21 18:51:22 +01:00
|
|
|
|
G_GNUC_END_IGNORE_DEPRECATIONS
|
2010-07-27 07:00:55 +02:00
|
|
|
|
|
2022-03-17 17:24:49 +01:00
|
|
|
|
g_assert_true (strv_set_equal (relocs,
|
2019-02-13 21:42:35 +01:00
|
|
|
|
"org.gtk.test.no-path",
|
|
|
|
|
"org.gtk.test.extends.base",
|
|
|
|
|
"org.gtk.test.extends.extended",
|
|
|
|
|
NULL));
|
|
|
|
|
|
2022-03-17 17:24:49 +01:00
|
|
|
|
g_assert_true (strv_set_equal (schemas,
|
2019-02-13 21:42:35 +01:00
|
|
|
|
"org.gtk.test",
|
|
|
|
|
"org.gtk.test.basic-types",
|
|
|
|
|
"org.gtk.test.complex-types",
|
|
|
|
|
"org.gtk.test.localized",
|
|
|
|
|
"org.gtk.test.binding",
|
|
|
|
|
"org.gtk.test.enums",
|
|
|
|
|
"org.gtk.test.enums.direct",
|
|
|
|
|
"org.gtk.test.range",
|
|
|
|
|
"org.gtk.test.range.direct",
|
|
|
|
|
"org.gtk.test.mapped",
|
|
|
|
|
"org.gtk.test.descriptions",
|
|
|
|
|
"org.gtk.test.per-desktop",
|
|
|
|
|
NULL));
|
2010-07-27 07:00:55 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-05 21:53:58 +02:00
|
|
|
|
static gboolean
|
|
|
|
|
map_func (GVariant *value,
|
|
|
|
|
gpointer *result,
|
|
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
gint *state = user_data;
|
|
|
|
|
gint v;
|
|
|
|
|
|
|
|
|
|
if (value)
|
|
|
|
|
v = g_variant_get_int32 (value);
|
|
|
|
|
else
|
|
|
|
|
v = -1;
|
|
|
|
|
|
|
|
|
|
if (*state == 0)
|
|
|
|
|
{
|
|
|
|
|
g_assert_cmpint (v, ==, 1);
|
|
|
|
|
(*state)++;
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
else if (*state == 1)
|
|
|
|
|
{
|
|
|
|
|
g_assert_cmpint (v, ==, 0);
|
|
|
|
|
(*state)++;
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (value);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
*result = g_variant_new_int32 (5);
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_get_mapped (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gint state;
|
|
|
|
|
gpointer p;
|
|
|
|
|
gint val;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.mapped");
|
|
|
|
|
g_settings_set_int (settings, "val", 1);
|
|
|
|
|
|
|
|
|
|
state = 0;
|
|
|
|
|
p = g_settings_get_mapped (settings, "val", map_func, &state);
|
|
|
|
|
val = g_variant_get_int32 ((GVariant*)p);
|
|
|
|
|
g_assert_cmpint (val, ==, 5);
|
|
|
|
|
|
|
|
|
|
g_variant_unref (p);
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2010-10-04 08:58:46 +02:00
|
|
|
|
static void
|
|
|
|
|
test_get_range (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
GVariant *range;
|
|
|
|
|
|
2013-12-21 18:51:22 +01:00
|
|
|
|
G_GNUC_BEGIN_IGNORE_DEPRECATIONS
|
2010-10-04 08:58:46 +02:00
|
|
|
|
settings = g_settings_new ("org.gtk.test.range");
|
|
|
|
|
range = g_settings_get_range (settings, "val");
|
|
|
|
|
check_and_free (range, "('range', <(2, 44)>)");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
range = g_settings_get_range (settings, "test");
|
|
|
|
|
check_and_free (range, "('enum', <['foo', 'bar', 'baz', 'quux']>)");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.enums");
|
|
|
|
|
range = g_settings_get_range (settings, "f-test");
|
|
|
|
|
check_and_free (range, "('flags', "
|
|
|
|
|
"<['mourning', 'laughing', 'talking', 'walking']>)");
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
range = g_settings_get_range (settings, "greeting");
|
|
|
|
|
check_and_free (range, "('type', <@as []>)");
|
|
|
|
|
g_object_unref (settings);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
G_GNUC_END_IGNORE_DEPRECATIONS
|
2010-10-04 08:58:46 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-11-16 11:38:04 +01:00
|
|
|
|
static void
|
|
|
|
|
test_schema_source (void)
|
|
|
|
|
{
|
|
|
|
|
GSettingsSchemaSource *parent;
|
|
|
|
|
GSettingsSchemaSource *source;
|
|
|
|
|
GSettingsBackend *backend;
|
|
|
|
|
GSettingsSchema *schema;
|
|
|
|
|
GError *error = NULL;
|
2021-06-04 14:09:24 +02:00
|
|
|
|
GSettings *settings, *child;
|
2011-11-16 11:38:04 +01:00
|
|
|
|
gboolean enabled;
|
|
|
|
|
|
|
|
|
|
backend = g_settings_backend_get_default ();
|
|
|
|
|
|
|
|
|
|
/* make sure it fails properly */
|
|
|
|
|
parent = g_settings_schema_source_get_default ();
|
2011-11-16 20:53:03 +01:00
|
|
|
|
source = g_settings_schema_source_new_from_directory ("/path/that/does/not/exist", parent, TRUE, &error);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (source);
|
2011-11-17 04:25:16 +01:00
|
|
|
|
g_assert_error (error, G_FILE_ERROR, G_FILE_ERROR_NOENT);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_clear_error (&error);
|
|
|
|
|
|
2018-08-01 14:03:07 +02:00
|
|
|
|
/* Test error handling of corrupt compiled files. */
|
|
|
|
|
source = g_settings_schema_source_new_from_directory ("schema-source-corrupt", parent, TRUE, &error);
|
|
|
|
|
g_assert_error (error, G_FILE_ERROR, G_FILE_ERROR_INVAL);
|
|
|
|
|
g_assert_null (source);
|
|
|
|
|
g_clear_error (&error);
|
|
|
|
|
|
|
|
|
|
/* Test error handling of empty compiled files. */
|
|
|
|
|
source = g_settings_schema_source_new_from_directory ("schema-source-empty", parent, TRUE, &error);
|
|
|
|
|
g_assert_error (error, G_FILE_ERROR, G_FILE_ERROR_INVAL);
|
|
|
|
|
g_assert_null (source);
|
|
|
|
|
g_clear_error (&error);
|
|
|
|
|
|
2011-11-16 11:38:04 +01:00
|
|
|
|
/* create a source with the parent */
|
2011-11-16 20:53:03 +01:00
|
|
|
|
source = g_settings_schema_source_new_from_directory ("schema-source", parent, TRUE, &error);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_assert_no_error (error);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (source);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* check recursive lookups are working */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.test", TRUE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
|
|
|
|
|
/* check recursive lookups for non-existent schemas */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.doesnotexist", TRUE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* check non-recursive for schema that only exists in lower layers */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.test", FALSE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* check non-recursive lookup for non-existent */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.doesnotexist", FALSE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* check non-recursive for schema that exists in toplevel */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.schemasourcecheck", FALSE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
|
|
|
|
|
/* check recursive for schema that exists in toplevel */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.schemasourcecheck", TRUE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* try to use it for something */
|
2021-06-04 14:09:24 +02:00
|
|
|
|
settings = g_settings_new_full (schema, backend, "/test/");
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
enabled = FALSE;
|
|
|
|
|
g_settings_get (settings, "enabled", "b", &enabled);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (enabled);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
2021-06-04 14:09:24 +02:00
|
|
|
|
/* Check that child schemas are resolved from the correct schema source, see glib#1884 */
|
|
|
|
|
child = g_settings_get_child (settings, "child");
|
|
|
|
|
g_settings_get (settings, "enabled", "b", &enabled);
|
|
|
|
|
|
|
|
|
|
g_object_unref (child);
|
|
|
|
|
g_object_unref (settings);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_settings_schema_source_unref (source);
|
|
|
|
|
|
|
|
|
|
/* try again, but with no parent */
|
2011-11-16 20:53:03 +01:00
|
|
|
|
source = g_settings_schema_source_new_from_directory ("schema-source", NULL, FALSE, NULL);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (source);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* should not find it this time, even if recursive... */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.test", FALSE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.test", TRUE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_null (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
|
|
|
|
/* should still find our own... */
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.schemasourcecheck", TRUE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
schema = g_settings_schema_source_lookup (source, "org.gtk.schemasourcecheck", FALSE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (schema);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
|
|
|
|
|
g_settings_schema_source_unref (source);
|
2019-01-23 17:25:33 +01:00
|
|
|
|
g_object_unref (backend);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
}
|
|
|
|
|
|
2014-11-19 18:45:06 +01:00
|
|
|
|
static void
|
|
|
|
|
test_schema_list_keys (void)
|
|
|
|
|
{
|
|
|
|
|
gchar **keys;
|
|
|
|
|
GSettingsSchemaSource *src = g_settings_schema_source_get_default ();
|
|
|
|
|
GSettingsSchema *schema = g_settings_schema_source_lookup (src, "org.gtk.test", TRUE);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_nonnull (schema);
|
2014-11-19 18:45:06 +01:00
|
|
|
|
|
|
|
|
|
keys = g_settings_schema_list_keys (schema);
|
|
|
|
|
|
2022-03-17 17:24:49 +01:00
|
|
|
|
g_assert_true (strv_set_equal ((const gchar * const *) keys,
|
2019-02-13 21:42:35 +01:00
|
|
|
|
"greeting",
|
|
|
|
|
"farewell",
|
|
|
|
|
NULL));
|
2014-11-19 18:45:06 +01:00
|
|
|
|
|
|
|
|
|
g_strfreev (keys);
|
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
}
|
|
|
|
|
|
2012-01-19 16:49:06 +01:00
|
|
|
|
static void
|
|
|
|
|
test_actions (void)
|
|
|
|
|
{
|
|
|
|
|
GAction *string, *toggle;
|
|
|
|
|
gboolean c1, c2, c3;
|
|
|
|
|
GSettings *settings;
|
2012-08-19 08:24:04 +02:00
|
|
|
|
gchar *name;
|
|
|
|
|
GVariantType *param_type;
|
|
|
|
|
gboolean enabled;
|
|
|
|
|
GVariantType *state_type;
|
|
|
|
|
GVariant *state;
|
2012-01-19 16:49:06 +01:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.basic-types");
|
|
|
|
|
string = g_settings_create_action (settings, "test-string");
|
|
|
|
|
toggle = g_settings_create_action (settings, "test-boolean");
|
|
|
|
|
g_object_unref (settings); /* should be held by the actions */
|
|
|
|
|
|
|
|
|
|
g_signal_connect (settings, "changed", G_CALLBACK (changed_cb2), &c1);
|
|
|
|
|
g_signal_connect (string, "notify::state", G_CALLBACK (changed_cb2), &c2);
|
|
|
|
|
g_signal_connect (toggle, "notify::state", G_CALLBACK (changed_cb2), &c3);
|
|
|
|
|
|
|
|
|
|
c1 = c2 = c3 = FALSE;
|
|
|
|
|
g_settings_set_string (settings, "test-string", "hello world");
|
|
|
|
|
check_and_free (g_action_get_state (string), "'hello world'");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (c1 && c2 && !c3);
|
2012-01-19 16:49:06 +01:00
|
|
|
|
c1 = c2 = c3 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_action_activate (string, g_variant_new_string ("hihi"));
|
|
|
|
|
check_and_free (g_settings_get_value (settings, "test-string"), "'hihi'");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (c1 && c2 && !c3);
|
2012-01-19 16:49:06 +01:00
|
|
|
|
c1 = c2 = c3 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_action_change_state (string, g_variant_new_string ("kthxbye"));
|
|
|
|
|
check_and_free (g_settings_get_value (settings, "test-string"), "'kthxbye'");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (c1 && c2 && !c3);
|
2012-01-19 16:49:06 +01:00
|
|
|
|
c1 = c2 = c3 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_action_change_state (toggle, g_variant_new_boolean (TRUE));
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_settings_get_boolean (settings, "test-boolean"));
|
|
|
|
|
g_assert_true (c1 && !c2 && c3);
|
2012-01-19 16:49:06 +01:00
|
|
|
|
c1 = c2 = c3 = FALSE;
|
|
|
|
|
|
|
|
|
|
g_action_activate (toggle, NULL);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (g_settings_get_boolean (settings, "test-boolean"));
|
|
|
|
|
g_assert_true (c1 && !c2 && c3);
|
2012-01-19 16:49:06 +01:00
|
|
|
|
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_object_get (string,
|
|
|
|
|
"name", &name,
|
|
|
|
|
"parameter-type", ¶m_type,
|
|
|
|
|
"enabled", &enabled,
|
|
|
|
|
"state-type", &state_type,
|
|
|
|
|
"state", &state,
|
|
|
|
|
NULL);
|
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (name, ==, "test-string");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_type_equal (param_type, G_VARIANT_TYPE_STRING));
|
|
|
|
|
g_assert_true (enabled);
|
|
|
|
|
g_assert_true (g_variant_type_equal (state_type, G_VARIANT_TYPE_STRING));
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_assert_cmpstr (g_variant_get_string (state, NULL), ==, "kthxbye");
|
|
|
|
|
|
|
|
|
|
g_free (name);
|
2017-02-27 11:08:16 +01:00
|
|
|
|
g_variant_type_free (param_type);
|
|
|
|
|
g_variant_type_free (state_type);
|
2012-08-19 08:24:04 +02:00
|
|
|
|
g_variant_unref (state);
|
|
|
|
|
|
2012-01-19 16:49:06 +01:00
|
|
|
|
g_object_unref (string);
|
|
|
|
|
g_object_unref (toggle);
|
|
|
|
|
}
|
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
static void
|
|
|
|
|
test_null_backend (void)
|
|
|
|
|
{
|
|
|
|
|
GSettingsBackend *backend;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar *str;
|
|
|
|
|
gboolean writable;
|
|
|
|
|
|
|
|
|
|
backend = g_null_settings_backend_new ();
|
2013-11-28 18:58:44 +01:00
|
|
|
|
settings = g_settings_new_with_backend_and_path ("org.gtk.test", backend, "/tests/");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2014-06-23 14:53:06 +02:00
|
|
|
|
g_object_get (settings, "schema-id", &str, NULL);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_assert_cmpstr (str, ==, "org.gtk.test");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "Hello, earthlings");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "goodbye world");
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "Hello, earthlings");
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
|
|
|
|
writable = g_settings_is_writable (settings, "greeting");
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_false (writable);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
|
2013-12-24 06:05:36 +01:00
|
|
|
|
g_settings_reset (settings, "greeting");
|
|
|
|
|
|
|
|
|
|
g_settings_delay (settings);
|
|
|
|
|
g_settings_set (settings, "greeting", "s", "goodbye world");
|
|
|
|
|
g_settings_apply (settings);
|
2021-06-16 12:52:29 +02:00
|
|
|
|
settings_assert_cmpstr (settings, "greeting", ==, "Hello, earthlings");
|
2013-12-24 06:05:36 +01:00
|
|
|
|
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
g_object_unref (backend);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
test_memory_backend (void)
|
|
|
|
|
{
|
|
|
|
|
GSettingsBackend *backend;
|
|
|
|
|
|
|
|
|
|
backend = g_memory_settings_backend_new ();
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (G_IS_SETTINGS_BACKEND (backend));
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_object_unref (backend);
|
|
|
|
|
}
|
|
|
|
|
|
2013-10-27 00:58:06 +02:00
|
|
|
|
static void
|
|
|
|
|
test_read_descriptions (void)
|
|
|
|
|
{
|
|
|
|
|
GSettingsSchema *schema;
|
|
|
|
|
GSettingsSchemaKey *key;
|
|
|
|
|
GSettings *settings;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
|
|
|
|
g_object_get (settings, "settings-schema", &schema, NULL);
|
|
|
|
|
key = g_settings_schema_get_key (schema, "greeting");
|
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (g_settings_schema_key_get_summary (key), ==, "A greeting");
|
|
|
|
|
g_assert_cmpstr (g_settings_schema_key_get_description (key), ==, "Greeting of the invading martians");
|
|
|
|
|
|
|
|
|
|
g_settings_schema_key_unref (key);
|
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.descriptions");
|
|
|
|
|
g_object_get (settings, "settings-schema", &schema, NULL);
|
|
|
|
|
key = g_settings_schema_get_key (schema, "a");
|
|
|
|
|
|
|
|
|
|
g_assert_cmpstr (g_settings_schema_key_get_summary (key), ==,
|
|
|
|
|
"a paragraph.\n\n"
|
|
|
|
|
"with some whitespace.\n\n"
|
|
|
|
|
"because not everyone has a great editor.\n\n"
|
|
|
|
|
"lots of space is as one.");
|
|
|
|
|
|
|
|
|
|
g_settings_schema_key_unref (key);
|
|
|
|
|
g_settings_schema_unref (schema);
|
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2013-11-28 08:01:48 +01:00
|
|
|
|
static void
|
|
|
|
|
test_default_value (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
2013-11-28 20:33:03 +01:00
|
|
|
|
GSettingsSchema *schema;
|
|
|
|
|
GSettingsSchemaKey *key;
|
2013-11-28 08:01:48 +01:00
|
|
|
|
GVariant *v;
|
2013-11-28 20:33:03 +01:00
|
|
|
|
const gchar *str;
|
2013-12-21 07:00:10 +01:00
|
|
|
|
gchar *s;
|
2013-11-28 08:01:48 +01:00
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test");
|
2013-11-28 20:33:03 +01:00
|
|
|
|
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);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_variant_type_equal (g_settings_schema_key_get_value_type (key), G_VARIANT_TYPE_STRING));
|
2013-11-28 20:33:03 +01:00
|
|
|
|
|
|
|
|
|
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);
|
2013-11-28 08:01:48 +01:00
|
|
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
2013-12-21 07:00:10 +01:00
|
|
|
|
s = g_settings_get_string (settings, "greeting");
|
|
|
|
|
g_assert_cmpstr (s, ==, "Hello, earthlings");
|
|
|
|
|
g_free (s);
|
2013-11-28 08:01:48 +01:00
|
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
}
|
|
|
|
|
|
2018-06-19 22:39:24 +02:00
|
|
|
|
static gboolean
|
|
|
|
|
string_map_func (GVariant *value,
|
|
|
|
|
gpointer *result,
|
|
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
const gchar *str;
|
|
|
|
|
|
|
|
|
|
str = g_variant_get_string (value, NULL);
|
|
|
|
|
*result = g_variant_new_string (str);
|
|
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Test that per-desktop values from org.gtk.test.gschema.override
|
|
|
|
|
* does not change default value if current desktop is not listed in
|
|
|
|
|
* $XDG_CURRENT_DESKTOP.
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_per_desktop (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
2023-01-14 04:15:47 +01:00
|
|
|
|
GAction *action_string;
|
2018-06-19 22:39:24 +02:00
|
|
|
|
TestObject *obj;
|
|
|
|
|
gpointer p;
|
|
|
|
|
gchar *str;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.per-desktop");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
if (!g_test_subprocess ())
|
|
|
|
|
{
|
2022-03-31 15:30:43 +02:00
|
|
|
|
g_test_trap_subprocess ("/gsettings/per-desktop/subprocess", 0,
|
|
|
|
|
G_TEST_SUBPROCESS_DEFAULT);
|
2018-06-19 22:39:24 +02:00
|
|
|
|
g_test_trap_assert_passed ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
str = g_settings_get_string (settings, "desktop");
|
|
|
|
|
g_assert_cmpstr (str, ==, "GNOME");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
p = g_settings_get_mapped (settings, "desktop", string_map_func, NULL);
|
|
|
|
|
|
|
|
|
|
str = g_variant_dup_string (p, NULL);
|
|
|
|
|
g_assert_cmpstr (str, ==, "GNOME");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
g_variant_unref (p);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "desktop", obj, "string", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_get (obj, "string", &str, NULL);
|
|
|
|
|
g_assert_cmpstr (str, ==, "GNOME");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2023-01-14 04:15:47 +01:00
|
|
|
|
action_string = g_settings_create_action (settings, "desktop");
|
|
|
|
|
check_and_free (g_action_get_state (action_string), "'GNOME'");
|
|
|
|
|
|
|
|
|
|
g_clear_object (&action_string);
|
2018-06-19 22:39:24 +02:00
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Test that per-desktop values from org.gtk.test.gschema.override
|
|
|
|
|
* are successfully loaded based on the value of $XDG_CURRENT_DESKTOP.
|
|
|
|
|
*/
|
|
|
|
|
static void
|
|
|
|
|
test_per_desktop_subprocess (void)
|
|
|
|
|
{
|
|
|
|
|
GSettings *settings;
|
2023-01-14 04:15:47 +01:00
|
|
|
|
GAction *action_string;
|
2018-06-19 22:39:24 +02:00
|
|
|
|
TestObject *obj;
|
|
|
|
|
gpointer p;
|
|
|
|
|
gchar *str;
|
|
|
|
|
|
|
|
|
|
g_setenv ("XDG_CURRENT_DESKTOP", "GNOME-Classic:GNOME", TRUE);
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new ("org.gtk.test.per-desktop");
|
|
|
|
|
obj = test_object_new ();
|
|
|
|
|
|
|
|
|
|
str = g_settings_get_string (settings, "desktop");
|
|
|
|
|
g_assert_cmpstr (str, ==, "GNOME Classic");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
p = g_settings_get_mapped (settings, "desktop", string_map_func, NULL);
|
|
|
|
|
|
|
|
|
|
str = g_variant_dup_string (p, NULL);
|
|
|
|
|
g_assert_cmpstr (str, ==, "GNOME Classic");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
|
|
|
|
g_variant_unref (p);
|
|
|
|
|
|
|
|
|
|
g_settings_bind (settings, "desktop", obj, "string", G_SETTINGS_BIND_DEFAULT);
|
|
|
|
|
|
|
|
|
|
g_object_get (obj, "string", &str, NULL);
|
|
|
|
|
g_assert_cmpstr (str, ==, "GNOME Classic");
|
|
|
|
|
g_free (str);
|
|
|
|
|
|
2023-01-14 04:15:47 +01:00
|
|
|
|
action_string = g_settings_create_action (settings, "desktop");
|
|
|
|
|
check_and_free (g_action_get_state (action_string), "'GNOME Classic'");
|
|
|
|
|
|
|
|
|
|
g_clear_object (&action_string);
|
2018-06-19 22:39:24 +02:00
|
|
|
|
g_object_unref (settings);
|
|
|
|
|
g_object_unref (obj);
|
|
|
|
|
}
|
|
|
|
|
|
2013-10-28 01:22:38 +01:00
|
|
|
|
static void
|
|
|
|
|
test_extended_schema (void)
|
|
|
|
|
{
|
2014-11-19 18:45:06 +01:00
|
|
|
|
GSettingsSchema *schema;
|
2013-10-28 01:22:38 +01:00
|
|
|
|
GSettings *settings;
|
|
|
|
|
gchar **keys;
|
|
|
|
|
|
|
|
|
|
settings = g_settings_new_with_path ("org.gtk.test.extends.extended", "/test/extendes/");
|
2014-11-19 18:45:06 +01:00
|
|
|
|
g_object_get (settings, "settings-schema", &schema, NULL);
|
|
|
|
|
keys = g_settings_schema_list_keys (schema);
|
2022-03-17 17:24:49 +01:00
|
|
|
|
g_assert_true (strv_set_equal ((const gchar * const *) keys, "int32", "string", "another-int32", NULL));
|
2013-10-28 01:22:38 +01:00
|
|
|
|
g_strfreev (keys);
|
|
|
|
|
g_object_unref (settings);
|
2014-11-19 18:45:06 +01:00
|
|
|
|
g_settings_schema_unref (schema);
|
2013-10-28 01:22:38 +01:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
int
|
|
|
|
|
main (int argc, char *argv[])
|
|
|
|
|
{
|
2013-11-12 05:17:32 +01:00
|
|
|
|
gchar *schema_text;
|
2018-06-19 22:39:24 +02:00
|
|
|
|
gchar *override_text;
|
2010-06-14 23:29:41 +02:00
|
|
|
|
gchar *enums;
|
2010-06-11 04:35:31 +02:00
|
|
|
|
gint result;
|
2021-02-10 22:21:36 +01:00
|
|
|
|
const KeyfileTestData keyfile_test_data_explicit_path = { "/tests/", "root", "tests", "/" };
|
|
|
|
|
const KeyfileTestData keyfile_test_data_empty_path = { "/", "root", "root", "/" };
|
|
|
|
|
const KeyfileTestData keyfile_test_data_long_path = {
|
|
|
|
|
"/tests/path/is/very/long/and/this/makes/some/comparisons/take/a/different/branch/",
|
|
|
|
|
"root",
|
|
|
|
|
"tests/path/is/very/long/and/this/makes/some/comparisons/take/a/different/branch",
|
|
|
|
|
"/"
|
|
|
|
|
};
|
2010-06-11 04:35:31 +02:00
|
|
|
|
|
2017-02-24 10:46:36 +01:00
|
|
|
|
/* Meson build sets this */
|
|
|
|
|
#ifdef TEST_LOCALE_PATH
|
|
|
|
|
if (g_str_has_suffix (TEST_LOCALE_PATH, "LC_MESSAGES"))
|
|
|
|
|
{
|
|
|
|
|
locale_dir = TEST_LOCALE_PATH G_DIR_SEPARATOR_S ".." G_DIR_SEPARATOR_S "..";
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2010-04-19 15:30:22 +02:00
|
|
|
|
setlocale (LC_ALL, "");
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_init (&argc, &argv, NULL);
|
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
if (!g_test_subprocess ())
|
|
|
|
|
{
|
2018-08-01 14:03:07 +02:00
|
|
|
|
GError *local_error = NULL;
|
2023-01-12 18:49:12 +01:00
|
|
|
|
char *subprocess_stdout = NULL;
|
|
|
|
|
|
2018-08-01 14:03:07 +02:00
|
|
|
|
/* A GVDB header is 6 guint32s, and requires a magic number in the first
|
|
|
|
|
* two guint32s. A set of zero bytes of a greater length is considered
|
|
|
|
|
* corrupt. */
|
|
|
|
|
const guint8 gschemas_compiled_corrupt[sizeof (guint32) * 7] = { 0, };
|
|
|
|
|
|
2012-11-24 21:58:36 +01:00
|
|
|
|
backend_set = g_getenv ("GSETTINGS_BACKEND") != NULL;
|
|
|
|
|
|
2013-06-01 04:33:22 +02:00
|
|
|
|
g_setenv ("XDG_DATA_DIRS", ".", TRUE);
|
2017-05-19 21:44:14 +02:00
|
|
|
|
g_setenv ("XDG_DATA_HOME", ".", TRUE);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_setenv ("GSETTINGS_SCHEMA_DIR", ".", TRUE);
|
2018-06-19 22:39:24 +02:00
|
|
|
|
g_setenv ("XDG_CURRENT_DESKTOP", "", TRUE);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
|
|
|
|
|
if (!backend_set)
|
|
|
|
|
g_setenv ("GSETTINGS_BACKEND", "memory", TRUE);
|
|
|
|
|
|
2013-06-01 04:33:22 +02:00
|
|
|
|
g_remove ("org.gtk.test.enums.xml");
|
2019-01-09 12:42:16 +01:00
|
|
|
|
/* #GLIB_MKENUMS is defined in meson.build */
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_spawn_command_line_sync (GLIB_MKENUMS " "
|
|
|
|
|
"--template " SRCDIR "/enums.xml.template "
|
|
|
|
|
SRCDIR "/testenum.h",
|
|
|
|
|
&enums, NULL, &result, NULL));
|
|
|
|
|
g_assert_cmpint (result, ==, 0);
|
|
|
|
|
g_assert_true (g_file_set_contents ("org.gtk.test.enums.xml", enums, -1, NULL));
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_free (enums);
|
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_file_get_contents (SRCDIR "/org.gtk.test.gschema.xml.orig", &schema_text, NULL, NULL));
|
|
|
|
|
g_assert_true (g_file_set_contents ("org.gtk.test.gschema.xml", schema_text, -1, NULL));
|
2017-02-27 11:08:16 +01:00
|
|
|
|
g_free (schema_text);
|
2013-11-12 05:17:32 +01:00
|
|
|
|
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_file_get_contents (SRCDIR "/org.gtk.test.gschema.override.orig", &override_text, NULL, NULL));
|
|
|
|
|
g_assert_true (g_file_set_contents ("org.gtk.test.gschema.override", override_text, -1, NULL));
|
2018-06-19 22:39:24 +02:00
|
|
|
|
g_free (override_text);
|
|
|
|
|
|
2013-06-01 04:33:22 +02:00
|
|
|
|
g_remove ("gschemas.compiled");
|
2019-01-09 12:42:16 +01:00
|
|
|
|
/* #GLIB_COMPILE_SCHEMAS is defined in meson.build */
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_spawn_command_line_sync (GLIB_COMPILE_SCHEMAS " --targetdir=. "
|
|
|
|
|
"--schema-file=org.gtk.test.enums.xml "
|
|
|
|
|
"--schema-file=org.gtk.test.gschema.xml "
|
|
|
|
|
"--override-file=org.gtk.test.gschema.override",
|
2023-01-12 18:49:12 +01:00
|
|
|
|
&subprocess_stdout, NULL, &result, NULL));
|
|
|
|
|
if (subprocess_stdout && *g_strstrip (subprocess_stdout) != '\0')
|
|
|
|
|
g_test_message ("%s", subprocess_stdout);
|
|
|
|
|
g_clear_pointer (&subprocess_stdout, g_free);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_cmpint (result, ==, 0);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
|
2013-05-20 12:38:41 +02:00
|
|
|
|
g_remove ("schema-source/gschemas.compiled");
|
2013-06-01 04:33:22 +02:00
|
|
|
|
g_mkdir ("schema-source", 0777);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_true (g_spawn_command_line_sync (GLIB_COMPILE_SCHEMAS " --targetdir=schema-source "
|
|
|
|
|
"--schema-file=" SRCDIR "/org.gtk.schemasourcecheck.gschema.xml",
|
2023-01-12 18:49:12 +01:00
|
|
|
|
&subprocess_stdout, NULL, &result, NULL));
|
|
|
|
|
if (subprocess_stdout && *g_strstrip (subprocess_stdout) != '\0')
|
|
|
|
|
g_test_message ("%s", subprocess_stdout);
|
|
|
|
|
g_clear_pointer (&subprocess_stdout, g_free);
|
2019-02-13 21:42:35 +01:00
|
|
|
|
g_assert_cmpint (result, ==, 0);
|
2018-08-01 14:03:07 +02:00
|
|
|
|
|
|
|
|
|
g_remove ("schema-source-corrupt/gschemas.compiled");
|
|
|
|
|
g_mkdir ("schema-source-corrupt", 0777);
|
|
|
|
|
g_file_set_contents ("schema-source-corrupt/gschemas.compiled",
|
|
|
|
|
(const gchar *) gschemas_compiled_corrupt,
|
|
|
|
|
sizeof (gschemas_compiled_corrupt),
|
|
|
|
|
&local_error);
|
|
|
|
|
g_assert_no_error (local_error);
|
|
|
|
|
|
|
|
|
|
g_remove ("schema-source-empty/gschemas.compiled");
|
|
|
|
|
g_mkdir ("schema-source-empty", 0777);
|
|
|
|
|
g_file_set_contents ("schema-source-empty/gschemas.compiled",
|
|
|
|
|
"", 0,
|
|
|
|
|
&local_error);
|
|
|
|
|
g_assert_no_error (local_error);
|
2013-06-01 04:33:22 +02:00
|
|
|
|
}
|
2011-11-16 11:38:04 +01:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/basic", test_basic);
|
2010-06-11 04:35:31 +02:00
|
|
|
|
|
|
|
|
|
if (!backend_set)
|
|
|
|
|
{
|
|
|
|
|
g_test_add_func ("/gsettings/no-schema", test_no_schema);
|
|
|
|
|
g_test_add_func ("/gsettings/unknown-key", test_unknown_key);
|
|
|
|
|
g_test_add_func ("/gsettings/wrong-type", test_wrong_type);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/wrong-path", test_wrong_path);
|
|
|
|
|
g_test_add_func ("/gsettings/no-path", test_no_path);
|
2010-06-11 04:35:31 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/basic-types", test_basic_types);
|
|
|
|
|
g_test_add_func ("/gsettings/complex-types", test_complex_types);
|
|
|
|
|
g_test_add_func ("/gsettings/changes", test_changes);
|
2010-05-11 19:48:19 +02:00
|
|
|
|
|
Rework the build system for a new tests approach
Perform a substantial cleanup of the build system with respect to
building and installing testcases.
First, Makefile.decl has been renamed glib.mk and substantially
expanded. We intend to add more stuff here in the future, like canned
rules for mkenums, marshallers, resources, etc.
By default, tests are no longer compiled as part of 'make'. They will
be built when 'make check' is run. The old behaviour can be obtained
with --enable-always-build-tests.
--disable-modular-tests is gone (because tests are no longer built by
default). There is no longer any way to cause 'make check' to be a
no-op, but that's not very useful anyway.
A new glibtests.m4 file is introduced. Along with glib.mk, this
provides for consistent handling of --enable-installed-tests and
--enable-always-build-tests (mentioned above).
Port our various test-installing Makefiles to the new framework.
This patch substantially improves the situation in the toplevel tests/
directory. Things are now somewhat under control there. There were
some tests being built that weren't even being run and we run those now.
The long-running GObject performance tests in this directory have been
removed from 'make check' because they take too long.
As an experiment, 'make check' now runs the testcases on win32 builds,
by default. We can't run them under gtester (since it uses a pipe to
communicate with the subprocess) so just toss them in TESTS. Most of
them are passing on win32.
Things are not quite done here, but this patch is already a substantial
improvement. More to come.
2013-05-30 06:07:32 +02:00
|
|
|
|
g_test_add_func ("/gsettings/l10n", test_l10n);
|
|
|
|
|
g_test_add_func ("/gsettings/l10n-context", test_l10n_context);
|
2023-07-21 20:48:34 +02:00
|
|
|
|
g_test_add_func ("/gsettings/l10n-time", test_l10n_time);
|
2010-05-11 19:48:19 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/delay-apply", test_delay_apply);
|
|
|
|
|
g_test_add_func ("/gsettings/delay-revert", test_delay_revert);
|
2013-12-21 18:51:22 +01:00
|
|
|
|
g_test_add_func ("/gsettings/delay-child", test_delay_child);
|
2021-06-16 12:40:38 +02:00
|
|
|
|
g_test_add_func ("/gsettings/delay-reset-key", test_delay_reset_key);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/atomic", test_atomic);
|
2010-07-05 09:09:36 +02:00
|
|
|
|
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/simple-binding", test_simple_binding);
|
|
|
|
|
g_test_add_func ("/gsettings/directional-binding", test_directional_binding);
|
|
|
|
|
g_test_add_func ("/gsettings/custom-binding", test_custom_binding);
|
2024-03-18 05:15:46 +01:00
|
|
|
|
g_test_add_func ("/gsettings/bind-with-mapping-closures", test_bind_with_mapping_closures);
|
|
|
|
|
g_test_add_func ("/gsettings/bind-with-mapping-closures-parameters", test_bind_with_mapping_closures_parameters);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/no-change-binding", test_no_change_binding);
|
2010-07-05 09:09:36 +02:00
|
|
|
|
g_test_add_func ("/gsettings/unbinding", test_unbind);
|
|
|
|
|
g_test_add_func ("/gsettings/writable-binding", test_bind_writable);
|
2010-06-11 04:35:31 +02:00
|
|
|
|
|
|
|
|
|
if (!backend_set)
|
|
|
|
|
{
|
|
|
|
|
g_test_add_func ("/gsettings/typesafe-binding", test_typesafe_binding);
|
|
|
|
|
g_test_add_func ("/gsettings/no-read-binding", test_no_read_binding);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
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);
|
2010-06-11 04:35:31 +02:00
|
|
|
|
g_test_add_func ("/gsettings/no-write-binding", test_no_write_binding);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_test_add_func ("/gsettings/no-write-binding/subprocess/fail", test_no_write_binding_fail);
|
|
|
|
|
g_test_add_func ("/gsettings/no-write-binding/subprocess/pass", test_no_write_binding_pass);
|
2010-06-11 04:35:31 +02:00
|
|
|
|
}
|
|
|
|
|
|
2019-03-04 13:27:28 +01:00
|
|
|
|
g_test_add ("/gsettings/keyfile", Fixture, NULL, setup, test_keyfile, teardown);
|
2021-02-10 22:21:36 +01:00
|
|
|
|
g_test_add ("/gsettings/keyfile/explicit-path", Fixture, &keyfile_test_data_explicit_path, setup, test_keyfile_no_path, teardown);
|
|
|
|
|
g_test_add ("/gsettings/keyfile/empty-path", Fixture, &keyfile_test_data_empty_path, setup, test_keyfile_no_path, teardown);
|
|
|
|
|
g_test_add ("/gsettings/keyfile/long-path", Fixture, &keyfile_test_data_long_path, setup, test_keyfile_no_path, teardown);
|
|
|
|
|
g_test_add ("/gsettings/keyfile/outside-root-path", Fixture, NULL, setup, test_keyfile_outside_root_path, teardown);
|
|
|
|
|
g_test_add ("/gsettings/keyfile/no-root-group", Fixture, NULL, setup, test_keyfile_no_root_group, teardown);
|
2010-04-22 03:03:53 +02:00
|
|
|
|
g_test_add_func ("/gsettings/child-schema", test_child_schema);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_add_func ("/gsettings/strinfo", test_strinfo);
|
|
|
|
|
g_test_add_func ("/gsettings/enums", test_enums);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_test_add_func ("/gsettings/enums/subprocess/non-enum-key", test_enums_non_enum_key);
|
|
|
|
|
g_test_add_func ("/gsettings/enums/subprocess/non-enum-value", test_enums_non_enum_value);
|
|
|
|
|
g_test_add_func ("/gsettings/enums/subprocess/range", test_enums_range);
|
|
|
|
|
g_test_add_func ("/gsettings/enums/subprocess/non-flags", test_enums_non_flags);
|
2010-07-02 00:58:56 +02:00
|
|
|
|
g_test_add_func ("/gsettings/flags", test_flags);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_test_add_func ("/gsettings/flags/subprocess/non-flags-key", test_flags_non_flags_key);
|
|
|
|
|
g_test_add_func ("/gsettings/flags/subprocess/non-flags-value", test_flags_non_flags_value);
|
|
|
|
|
g_test_add_func ("/gsettings/flags/subprocess/range", test_flags_range);
|
|
|
|
|
g_test_add_func ("/gsettings/flags/subprocess/non-enum", test_flags_non_enum);
|
2010-06-14 23:29:41 +02:00
|
|
|
|
g_test_add_func ("/gsettings/range", test_range);
|
2012-11-24 21:58:36 +01:00
|
|
|
|
g_test_add_func ("/gsettings/range/subprocess/high", test_range_high);
|
|
|
|
|
g_test_add_func ("/gsettings/range/subprocess/low", test_range_low);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/list-items", test_list_items);
|
2010-07-27 07:00:55 +02:00
|
|
|
|
g_test_add_func ("/gsettings/list-schemas", test_list_schemas);
|
2010-07-05 21:53:58 +02:00
|
|
|
|
g_test_add_func ("/gsettings/mapped", test_get_mapped);
|
2010-10-04 08:58:46 +02:00
|
|
|
|
g_test_add_func ("/gsettings/get-range", test_get_range);
|
2011-11-16 11:38:04 +01:00
|
|
|
|
g_test_add_func ("/gsettings/schema-source", test_schema_source);
|
2014-11-19 18:45:06 +01:00
|
|
|
|
g_test_add_func ("/gsettings/schema-list-keys", test_schema_list_keys);
|
2012-01-19 16:49:06 +01:00
|
|
|
|
g_test_add_func ("/gsettings/actions", test_actions);
|
2013-06-03 02:00:21 +02:00
|
|
|
|
g_test_add_func ("/gsettings/null-backend", test_null_backend);
|
|
|
|
|
g_test_add_func ("/gsettings/memory-backend", test_memory_backend);
|
2013-10-27 00:58:06 +02:00
|
|
|
|
g_test_add_func ("/gsettings/read-descriptions", test_read_descriptions);
|
2013-10-28 01:22:38 +01:00
|
|
|
|
g_test_add_func ("/gsettings/test-extended-schema", test_extended_schema);
|
2013-11-28 08:01:48 +01:00
|
|
|
|
g_test_add_func ("/gsettings/default-value", test_default_value);
|
2018-06-19 22:39:24 +02:00
|
|
|
|
g_test_add_func ("/gsettings/per-desktop", test_per_desktop);
|
|
|
|
|
g_test_add_func ("/gsettings/per-desktop/subprocess", test_per_desktop_subprocess);
|
2010-04-17 07:43:58 +02:00
|
|
|
|
|
2010-06-11 04:35:31 +02:00
|
|
|
|
result = g_test_run ();
|
|
|
|
|
|
2010-06-17 20:05:40 +02:00
|
|
|
|
g_settings_sync ();
|
2010-06-11 04:35:31 +02:00
|
|
|
|
|
2019-01-23 17:26:09 +01:00
|
|
|
|
/* FIXME: Due to the way #GSettings objects can be used without specifying a
|
|
|
|
|
* backend, the default backend is leaked. In order to be able to run this
|
|
|
|
|
* test under valgrind and get meaningful checking for real leaks, use this
|
|
|
|
|
* hack to drop the final reference to the default #GSettingsBackend.
|
|
|
|
|
*
|
|
|
|
|
* This should not be used in production code. */
|
|
|
|
|
{
|
|
|
|
|
GSettingsBackend *backend;
|
|
|
|
|
|
|
|
|
|
backend = g_settings_backend_get_default ();
|
|
|
|
|
g_object_unref (backend); /* reference from the *_get_default() call */
|
|
|
|
|
g_assert_finalize_object (backend); /* singleton reference owned by GLib */
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-11 04:35:31 +02:00
|
|
|
|
return result;
|
2010-04-17 07:43:58 +02:00
|
|
|
|
}
|