/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */ /* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * * Copyright 2017 Red Hat, Inc. */ #include "nm-default.h" #include "nm-meta-setting-access.h" #include "nm-utils/nm-test-utils.h" /*****************************************************************************/ static void test_client_meta_check (void) { const NMMetaSettingInfoEditor *const*infos_p; NMMetaSettingType m; guint p; G_STATIC_ASSERT (G_STRUCT_OFFSET (NMMetaAbstractInfo, meta_type) == G_STRUCT_OFFSET (NMMetaSettingInfoEditor, meta_type)); G_STATIC_ASSERT (G_STRUCT_OFFSET (NMMetaAbstractInfo, meta_type) == G_STRUCT_OFFSET (NMMetaPropertyInfo, meta_type)); for (m = 0; m < _NM_META_SETTING_TYPE_NUM; m++) { const NMMetaSettingInfo *info = &nm_meta_setting_infos[m]; GType gtype; g_assert (info); g_assert (info->meta_type == m); g_assert (info->setting_name); g_assert (info->get_setting_gtype); gtype = info->get_setting_gtype (); g_assert (gtype != NM_TYPE_SETTING); { nm_auto_unref_gtypeclass GTypeClass *gclass = g_type_class_ref (gtype); g_assert (G_TYPE_CHECK_CLASS_TYPE (gclass, gtype)); } { gs_unref_object NMSetting *setting = g_object_new (gtype, NULL); g_assert (NM_IS_SETTING (setting)); g_assert (G_TYPE_CHECK_INSTANCE_TYPE (setting, gtype)); g_assert_cmpstr (nm_setting_get_name (setting), ==, info->setting_name); } } for (m = 0; m < _NM_META_SETTING_TYPE_NUM; m++) { const NMMetaSettingInfoEditor *info = &nm_meta_setting_infos_editor[m]; g_assert (info); g_assert (info->meta_type == &nm_meta_type_setting_info_editor); g_assert (info->general); g_assert (info->general == &nm_meta_setting_infos[m]); g_assert_cmpstr (info->general->setting_name, ==, info->meta_type->get_name ((const NMMetaAbstractInfo *) info, FALSE)); g_assert_cmpstr ("name", ==, info->meta_type->get_name ((const NMMetaAbstractInfo *) info, TRUE)); g_assert (info->properties_num == NM_PTRARRAY_LEN (info->properties)); if (info->properties_num) { gs_unref_hashtable GHashTable *property_names = g_hash_table_new (nm_str_hash, g_str_equal); g_assert (info->properties); for (p = 0; p < info->properties_num; p++) { const NMMetaPropertyInfo *pi = info->properties[p]; g_assert (pi); g_assert (pi->meta_type == &nm_meta_type_property_info); g_assert (pi->setting_info == info); g_assert (pi->property_name); g_assert (g_hash_table_add (property_names, (gpointer) pi->property_name)); g_assert_cmpstr (pi->property_name, ==, pi->meta_type->get_name ((const NMMetaAbstractInfo *) pi, FALSE)); g_assert_cmpstr (pi->property_name, ==, pi->meta_type->get_name ((const NMMetaAbstractInfo *) pi, TRUE)); g_assert (pi->property_type); g_assert (pi->property_type->get_fcn); } g_assert (!info->properties[info->properties_num]); } else g_assert (!info->properties); if (info->valid_parts) { gsize i, l; gs_unref_hashtable GHashTable *dup = g_hash_table_new (nm_direct_hash, NULL); l = NM_PTRARRAY_LEN (info->valid_parts); g_assert (l >= 2); for (i = 0; info->valid_parts[i]; i++) { g_assert (info->valid_parts[i]->setting_info); g_assert (g_hash_table_add (dup, (gpointer) info->valid_parts[i]->setting_info)); if (i == 0) { g_assert (info->valid_parts[i]->setting_info == &nm_meta_setting_infos_editor[NM_META_SETTING_TYPE_CONNECTION]); g_assert (info->valid_parts[i]->mandatory); } if (i == 1) { g_assert (info->valid_parts[i]->setting_info == &nm_meta_setting_infos_editor[m]); g_assert (info->valid_parts[i]->mandatory); } } g_assert (i == l); } } for (m = 0; m < _NM_META_SETTING_TYPE_NUM; m++) { const NMMetaSettingInfoEditor *info = &nm_meta_setting_infos_editor[m]; g_assert (nm_meta_setting_info_editor_find_by_name (info->general->setting_name, FALSE) == info); g_assert (nm_meta_setting_info_editor_find_by_gtype (info->general->get_setting_gtype ()) == info); for (p = 0; p < info->properties_num; p++) { const NMMetaPropertyInfo *pi = info->properties[p]; g_assert (nm_meta_setting_info_editor_get_property_info (info, pi->property_name) == pi); g_assert (nm_meta_property_info_find_by_name (info->general->setting_name, pi->property_name) == pi); } } infos_p = nm_meta_setting_infos_editor_p (); g_assert (infos_p); for (m = 0; m < _NM_META_SETTING_TYPE_NUM; m++) g_assert (infos_p[m] == &nm_meta_setting_infos_editor[m]); g_assert (!infos_p[m]); } /*****************************************************************************/ NMTST_DEFINE (); int main (int argc, char **argv) { nmtst_init (&argc, &argv, TRUE); g_test_add_func ("/client/meta/check", test_client_meta_check); return g_test_run (); }