mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 07:56:17 +01:00
Improve GSettings test coverage
This commit is contained in:
parent
f89e9deaec
commit
eeb4951c47
@ -724,7 +724,8 @@ enum
|
|||||||
PROP_NO_READ,
|
PROP_NO_READ,
|
||||||
PROP_NO_WRITE,
|
PROP_NO_WRITE,
|
||||||
PROP_STRV,
|
PROP_STRV,
|
||||||
PROP_ENUM
|
PROP_ENUM,
|
||||||
|
PROP_FLAGS
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
@ -746,6 +747,7 @@ typedef struct
|
|||||||
gchar *no_write_prop;
|
gchar *no_write_prop;
|
||||||
gchar **strv_prop;
|
gchar **strv_prop;
|
||||||
guint enum_prop;
|
guint enum_prop;
|
||||||
|
guint flags_prop;
|
||||||
} TestObject;
|
} TestObject;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
@ -822,6 +824,9 @@ test_object_get_property (GObject *object,
|
|||||||
case PROP_ENUM:
|
case PROP_ENUM:
|
||||||
g_value_set_enum (value, test_object->enum_prop);
|
g_value_set_enum (value, test_object->enum_prop);
|
||||||
break;
|
break;
|
||||||
|
case PROP_FLAGS:
|
||||||
|
g_value_set_flags (value, test_object->flags_prop);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
@ -883,6 +888,9 @@ test_object_set_property (GObject *object,
|
|||||||
case PROP_ENUM:
|
case PROP_ENUM:
|
||||||
test_object->enum_prop = g_value_get_enum (value);
|
test_object->enum_prop = g_value_get_enum (value);
|
||||||
break;
|
break;
|
||||||
|
case PROP_FLAGS:
|
||||||
|
test_object->flags_prop = g_value_get_flags (value);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
@ -911,6 +919,28 @@ test_enum_get_type (void)
|
|||||||
return define_type_id;
|
return define_type_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GType
|
||||||
|
test_flags_get_type (void)
|
||||||
|
{
|
||||||
|
static volatile gsize define_type_id = 0;
|
||||||
|
|
||||||
|
if (g_once_init_enter (&define_type_id))
|
||||||
|
{
|
||||||
|
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);
|
||||||
|
g_once_init_leave (&define_type_id, type_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
return define_type_id;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_object_class_init (TestObjectClass *class)
|
test_object_class_init (TestObjectClass *class)
|
||||||
{
|
{
|
||||||
@ -950,6 +980,8 @@ test_object_class_init (TestObjectClass *class)
|
|||||||
g_param_spec_boxed ("strv", "", "", G_TYPE_STRV, G_PARAM_READWRITE));
|
g_param_spec_boxed ("strv", "", "", G_TYPE_STRV, G_PARAM_READWRITE));
|
||||||
g_object_class_install_property (gobject_class, PROP_ENUM,
|
g_object_class_install_property (gobject_class, PROP_ENUM,
|
||||||
g_param_spec_enum ("enum", "", "", test_enum_get_type (), TEST_ENUM_FOO, G_PARAM_READWRITE));
|
g_param_spec_enum ("enum", "", "", test_enum_get_type (), TEST_ENUM_FOO, G_PARAM_READWRITE));
|
||||||
|
g_object_class_install_property (gobject_class, PROP_FLAGS,
|
||||||
|
g_param_spec_flags ("flags", "", "", test_flags_get_type (), TEST_FLAGS_NONE, G_PARAM_READWRITE));
|
||||||
}
|
}
|
||||||
|
|
||||||
static TestObject *
|
static TestObject *
|
||||||
@ -1156,6 +1188,20 @@ test_simple_binding (void)
|
|||||||
g_object_get (obj, "enum", &i, NULL);
|
g_object_get (obj, "enum", &i, NULL);
|
||||||
g_assert_cmpint (i, ==, TEST_ENUM_BAZ);
|
g_assert_cmpint (i, ==, TEST_ENUM_BAZ);
|
||||||
|
|
||||||
|
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);
|
||||||
|
|
||||||
g_object_unref (obj);
|
g_object_unref (obj);
|
||||||
g_object_unref (settings);
|
g_object_unref (settings);
|
||||||
}
|
}
|
||||||
@ -1721,6 +1767,7 @@ static void
|
|||||||
test_range (void)
|
test_range (void)
|
||||||
{
|
{
|
||||||
GSettings *settings, *direct;
|
GSettings *settings, *direct;
|
||||||
|
GVariant *value;
|
||||||
|
|
||||||
settings = g_settings_new ("org.gtk.test.range");
|
settings = g_settings_new ("org.gtk.test.range");
|
||||||
direct = g_settings_new ("org.gtk.test.range.direct");
|
direct = g_settings_new ("org.gtk.test.range.direct");
|
||||||
@ -1748,6 +1795,16 @@ test_range (void)
|
|||||||
g_settings_set_int (direct, "val", 1);
|
g_settings_set_int (direct, "val", 1);
|
||||||
g_assert_cmpint (g_settings_get_int (direct, "val"), ==, 1);
|
g_assert_cmpint (g_settings_get_int (direct, "val"), ==, 1);
|
||||||
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 33);
|
g_assert_cmpint (g_settings_get_int (settings, "val"), ==, 33);
|
||||||
|
|
||||||
|
value = g_variant_new_int32 (1);
|
||||||
|
g_assert (!g_settings_range_check (settings, "val", value));
|
||||||
|
g_variant_unref (value);
|
||||||
|
value = g_variant_new_int32 (33);
|
||||||
|
g_assert (g_settings_range_check (settings, "val", value));
|
||||||
|
g_variant_unref (value);
|
||||||
|
value = g_variant_new_int32 (45);
|
||||||
|
g_assert (!g_settings_range_check (settings, "val", value));
|
||||||
|
g_variant_unref (value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
@ -2011,6 +2068,11 @@ test_actions (void)
|
|||||||
GAction *string, *toggle;
|
GAction *string, *toggle;
|
||||||
gboolean c1, c2, c3;
|
gboolean c1, c2, c3;
|
||||||
GSettings *settings;
|
GSettings *settings;
|
||||||
|
gchar *name;
|
||||||
|
GVariantType *param_type;
|
||||||
|
gboolean enabled;
|
||||||
|
GVariantType *state_type;
|
||||||
|
GVariant *state;
|
||||||
|
|
||||||
settings = g_settings_new ("org.gtk.test.basic-types");
|
settings = g_settings_new ("org.gtk.test.basic-types");
|
||||||
string = g_settings_create_action (settings, "test-string");
|
string = g_settings_create_action (settings, "test-string");
|
||||||
@ -2046,6 +2108,23 @@ test_actions (void)
|
|||||||
g_assert (!g_settings_get_boolean (settings, "test-boolean"));
|
g_assert (!g_settings_get_boolean (settings, "test-boolean"));
|
||||||
g_assert (c1 && !c2 && c3);
|
g_assert (c1 && !c2 && c3);
|
||||||
|
|
||||||
|
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");
|
||||||
|
g_assert (g_variant_type_equal (param_type, G_VARIANT_TYPE_STRING));
|
||||||
|
g_assert (enabled);
|
||||||
|
g_assert (g_variant_type_equal (state_type, G_VARIANT_TYPE_STRING));
|
||||||
|
g_assert_cmpstr (g_variant_get_string (state, NULL), ==, "kthxbye");
|
||||||
|
|
||||||
|
g_free (name);
|
||||||
|
g_variant_unref (state);
|
||||||
|
|
||||||
g_object_unref (string);
|
g_object_unref (string);
|
||||||
g_object_unref (toggle);
|
g_object_unref (toggle);
|
||||||
}
|
}
|
||||||
|
@ -120,6 +120,9 @@
|
|||||||
<key name="enum" enum="org.gtk.test.TestEnum">
|
<key name="enum" enum="org.gtk.test.TestEnum">
|
||||||
<default>'foo'</default>
|
<default>'foo'</default>
|
||||||
</key>
|
</key>
|
||||||
|
<key name="flags" flags="org.gtk.test.TestFlags">
|
||||||
|
<default>['mourning', 'laughing']</default>
|
||||||
|
</key>
|
||||||
</schema>
|
</schema>
|
||||||
|
|
||||||
<schema id='org.gtk.test.enums' path='/tests/enums/'>
|
<schema id='org.gtk.test.enums' path='/tests/enums/'>
|
||||||
|
Loading…
Reference in New Issue
Block a user