summaryrefslogtreecommitdiff
path: root/libnm-core/tests/test-general.c
diff options
context:
space:
mode:
Diffstat (limited to 'libnm-core/tests/test-general.c')
-rw-r--r--libnm-core/tests/test-general.c168
1 files changed, 168 insertions, 0 deletions
diff --git a/libnm-core/tests/test-general.c b/libnm-core/tests/test-general.c
index bd144f384..e94836527 100644
--- a/libnm-core/tests/test-general.c
+++ b/libnm-core/tests/test-general.c
@@ -32,6 +32,7 @@
#include "nm-setting-private.h"
#include "nm-utils.h"
#include "nm-core-internal.h"
+#include "nm-core-tests-enum-types.h"
#include "nm-setting-8021x.h"
#include "nm-setting-adsl.h"
@@ -62,6 +63,7 @@
#include "nm-glib-compat.h"
#include "nm-test-utils.h"
+#include "test-general-enums.h"
static void
vpn_check_func (const char *key, const char *value, gpointer user_data)
@@ -1969,6 +1971,7 @@ test_connection_diff_a_only (void)
{ NM_SETTING_CONNECTION_AUTOCONNECT_SLAVES, NM_SETTING_DIFF_RESULT_IN_A },
{ NM_SETTING_CONNECTION_SECONDARIES, NM_SETTING_DIFF_RESULT_IN_A },
{ NM_SETTING_CONNECTION_GATEWAY_PING_TIMEOUT, NM_SETTING_DIFF_RESULT_IN_A },
+ { NM_SETTING_CONNECTION_METERED, NM_SETTING_DIFF_RESULT_IN_A },
{ NULL, NM_SETTING_DIFF_RESULT_UNKNOWN }
} },
{ NM_SETTING_WIRED_SETTING_NAME, {
@@ -1983,6 +1986,8 @@ test_connection_diff_a_only (void)
{ NM_SETTING_WIRED_S390_SUBCHANNELS, NM_SETTING_DIFF_RESULT_IN_A },
{ NM_SETTING_WIRED_S390_NETTYPE, NM_SETTING_DIFF_RESULT_IN_A },
{ NM_SETTING_WIRED_S390_OPTIONS, NM_SETTING_DIFF_RESULT_IN_A },
+ { NM_SETTING_WIRED_WAKE_ON_LAN, NM_SETTING_DIFF_RESULT_IN_A },
+ { NM_SETTING_WIRED_WAKE_ON_LAN_PASSWORD, NM_SETTING_DIFF_RESULT_IN_A },
{ NULL, NM_SETTING_DIFF_RESULT_UNKNOWN },
} },
{ NM_SETTING_IP4_CONFIG_SETTING_NAME, {
@@ -4448,6 +4453,166 @@ test_nm_utils_ptrarray_find_binary_search (void)
/******************************************************************************/
+static int
+_test_nm_in_set_get (int *call_counter, gboolean allow_called, int value)
+{
+ g_assert (call_counter);
+ *call_counter += 1;
+ if (!allow_called)
+ g_assert_not_reached ();
+ return value;
+}
+
+static void
+_test_nm_in_set_assert (int *call_counter, int expected)
+{
+ g_assert (call_counter);
+ g_assert_cmpint (expected, ==, *call_counter);
+ *call_counter = 0;
+}
+
+static void
+test_nm_in_set (void)
+{
+ int call_counter = 0;
+
+#define G(x) _test_nm_in_set_get (&call_counter, TRUE, x)
+#define N(x) _test_nm_in_set_get (&call_counter, FALSE, x)
+#define _ASSERT(expected, expr) \
+ G_STMT_START { \
+ _test_nm_in_set_assert (&call_counter, 0); \
+ g_assert (expr); \
+ _test_nm_in_set_assert (&call_counter, (expected)); \
+ } G_STMT_END
+ _ASSERT (1, !NM_IN_SET (-1, G( 1)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1)));
+
+ _ASSERT (2, !NM_IN_SET (-1, G( 1), G( 2)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N( 2)));
+ _ASSERT (2, NM_IN_SET (-1, G( 1), G(-1)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N(-1)));
+
+ _ASSERT (3, !NM_IN_SET (-1, G( 1), G( 2), G( 3)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N( 2), N( 3)));
+ _ASSERT (2, NM_IN_SET (-1, G( 1), G(-1), N( 3)));
+ _ASSERT (3, NM_IN_SET (-1, G( 1), G( 2), G(-1)));
+ _ASSERT (2, NM_IN_SET (-1, G( 1), G(-1), N(-1)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N( 2), N(-1)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N(-1), N( 3)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N(-1), N(-1)));
+
+ _ASSERT (4, !NM_IN_SET (-1, G( 1), G( 2), G( 3), G( 4)));
+ _ASSERT (1, NM_IN_SET (-1, G(-1), N( 2), N( 3), N( 4)));
+ _ASSERT (2, NM_IN_SET (-1, G( 1), G(-1), N( 3), N( 4)));
+ _ASSERT (3, NM_IN_SET (-1, G( 1), G( 2), G(-1), N( 4)));
+ _ASSERT (4, NM_IN_SET (-1, G( 1), G( 2), G( 3), G(-1)));
+
+ _ASSERT (4, NM_IN_SET (-1, G( 1), G( 2), G( 3), G(-1), G( 5)));
+
+ _ASSERT (1, !NM_IN_SET_SE (-1, G( 1)));
+ _ASSERT (1, NM_IN_SET_SE (-1, G(-1)));
+
+ _ASSERT (2, !NM_IN_SET_SE (-1, G( 1), G( 2)));
+ _ASSERT (2, NM_IN_SET_SE (-1, G(-1), G( 2)));
+ _ASSERT (2, NM_IN_SET_SE (-1, G( 1), G(-1)));
+ _ASSERT (2, NM_IN_SET_SE (-1, G(-1), G(-1)));
+
+ _ASSERT (3, !NM_IN_SET_SE (-1, G( 1), G( 2), G( 3)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G(-1), G( 2), G( 3)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G( 1), G(-1), G( 3)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G( 1), G( 2), G(-1)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G( 1), G(-1), G(-1)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G(-1), G( 2), G(-1)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G(-1), G(-1), G( 3)));
+ _ASSERT (3, NM_IN_SET_SE (-1, G(-1), G(-1), G(-1)));
+
+ _ASSERT (4, !NM_IN_SET_SE (-1, G( 1), G( 2), G( 3), G( 4)));
+ _ASSERT (4, NM_IN_SET_SE (-1, G(-1), G( 2), G( 3), G( 4)));
+ _ASSERT (4, NM_IN_SET_SE (-1, G( 1), G(-1), G( 3), G( 4)));
+ _ASSERT (4, NM_IN_SET_SE (-1, G( 1), G( 2), G(-1), G( 4)));
+ _ASSERT (4, NM_IN_SET_SE (-1, G( 1), G( 2), G( 3), G(-1)));
+
+ _ASSERT (5, NM_IN_SET_SE (-1, G( 1), G( 2), G( 3), G(-1), G( 5)));
+#undef G
+#undef N
+#undef _ASSERT
+}
+
+/******************************************************************************/
+
+static void
+test_nm_utils_enum_from_str_do (GType type, const char *str,
+ gboolean exp_result, int exp_flags,
+ const char *exp_err_token)
+{
+ int flags = 1;
+ char *err_token = NULL;
+ gboolean result;
+
+ result = nm_utils_enum_from_str (type, str, &flags, &err_token);
+
+ g_assert (result == exp_result);
+ g_assert_cmpint (flags, ==, exp_flags);
+ g_assert_cmpstr (err_token, ==, exp_err_token);
+
+ g_free (err_token);
+}
+
+static void
+test_nm_utils_enum_to_str_do (GType type, int flags, const char *exp_str)
+{
+ char *str;
+
+ str = nm_utils_enum_to_str (type, flags);
+ g_assert_cmpstr (str, ==, exp_str);
+ g_free (str);
+}
+
+static void test_nm_utils_enum (void)
+{
+ GType bool_enum = nm_test_general_bool_enum_get_type();
+ GType meta_flags = nm_test_general_meta_flags_get_type();
+ GType color_flags = nm_test_general_color_flags_get_type();
+
+ test_nm_utils_enum_to_str_do (bool_enum, NM_TEST_GENERAL_BOOL_ENUM_YES, "yes");
+ test_nm_utils_enum_to_str_do (bool_enum, NM_TEST_GENERAL_BOOL_ENUM_UNKNOWN, "unknown");
+ test_nm_utils_enum_to_str_do (bool_enum, NM_TEST_GENERAL_BOOL_ENUM_INVALID, NULL);
+
+ test_nm_utils_enum_to_str_do (meta_flags, NM_TEST_GENERAL_META_FLAGS_NONE, "");
+ test_nm_utils_enum_to_str_do (meta_flags, NM_TEST_GENERAL_META_FLAGS_BAZ, "baz");
+ test_nm_utils_enum_to_str_do (meta_flags, NM_TEST_GENERAL_META_FLAGS_FOO |
+ NM_TEST_GENERAL_META_FLAGS_BAR |
+ NM_TEST_GENERAL_META_FLAGS_BAZ, "foo,bar,baz");
+
+ test_nm_utils_enum_to_str_do (color_flags, NM_TEST_GENERAL_COLOR_FLAGS_RED, "red");
+ test_nm_utils_enum_to_str_do (color_flags, NM_TEST_GENERAL_COLOR_FLAGS_WHITE, "");
+ test_nm_utils_enum_to_str_do (color_flags, NM_TEST_GENERAL_COLOR_FLAGS_RED |
+ NM_TEST_GENERAL_COLOR_FLAGS_GREEN, "red,green");
+
+ test_nm_utils_enum_from_str_do (bool_enum, "", FALSE, 0, NULL);
+ test_nm_utils_enum_from_str_do (bool_enum, " ", FALSE, 0, NULL);
+ test_nm_utils_enum_from_str_do (bool_enum, "invalid", FALSE, 0, NULL);
+ test_nm_utils_enum_from_str_do (bool_enum, "yes", TRUE, NM_TEST_GENERAL_BOOL_ENUM_YES, NULL);
+ test_nm_utils_enum_from_str_do (bool_enum, "no", TRUE, NM_TEST_GENERAL_BOOL_ENUM_NO, NULL);
+ test_nm_utils_enum_from_str_do (bool_enum, "yes,no", FALSE, 0, NULL);
+
+ test_nm_utils_enum_from_str_do (meta_flags, "", TRUE, 0, NULL);
+ test_nm_utils_enum_from_str_do (meta_flags, " ", TRUE, 0, NULL);
+ test_nm_utils_enum_from_str_do (meta_flags, "foo", TRUE, NM_TEST_GENERAL_META_FLAGS_FOO, NULL);
+ test_nm_utils_enum_from_str_do (meta_flags, "foo,baz", TRUE, NM_TEST_GENERAL_META_FLAGS_FOO |
+ NM_TEST_GENERAL_META_FLAGS_BAZ, NULL);
+ test_nm_utils_enum_from_str_do (meta_flags, "foo,,bar", TRUE, NM_TEST_GENERAL_META_FLAGS_FOO |
+ NM_TEST_GENERAL_META_FLAGS_BAR, NULL);
+ test_nm_utils_enum_from_str_do (meta_flags, "foo,baz,quux,bar", FALSE, 0, "quux");
+
+ test_nm_utils_enum_from_str_do (color_flags, "green", TRUE, NM_TEST_GENERAL_COLOR_FLAGS_GREEN, NULL);
+ test_nm_utils_enum_from_str_do (color_flags, "blue,red", TRUE, NM_TEST_GENERAL_COLOR_FLAGS_BLUE |
+ NM_TEST_GENERAL_COLOR_FLAGS_RED, NULL);
+ test_nm_utils_enum_from_str_do (color_flags, "blue,white", FALSE, 0, "white");
+}
+
+/******************************************************************************/
+
NMTST_DEFINE ();
int main (int argc, char **argv)
@@ -4455,6 +4620,7 @@ int main (int argc, char **argv)
nmtst_init (&argc, &argv, TRUE);
/* The tests */
+ g_test_add_func ("/core/general/test_nm_in_set", test_nm_in_set);
g_test_add_func ("/core/general/test_setting_vpn_items", test_setting_vpn_items);
g_test_add_func ("/core/general/test_setting_vpn_update_secrets", test_setting_vpn_update_secrets);
g_test_add_func ("/core/general/test_setting_vpn_modify_during_foreach", test_setting_vpn_modify_during_foreach);
@@ -4552,6 +4718,8 @@ int main (int argc, char **argv)
g_test_add_func ("/core/general/_glib_compat_g_ptr_array_insert", test_g_ptr_array_insert);
g_test_add_func ("/core/general/_nm_utils_ptrarray_find_binary_search", test_nm_utils_ptrarray_find_binary_search);
+ g_test_add_func ("/core/general/test_nm_utils_enum", test_nm_utils_enum);
+
return g_test_run ();
}