summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Haller <thaller@redhat.com>2015-06-13 11:37:21 +0200
committerThomas Haller <thaller@redhat.com>2015-07-02 14:21:42 +0200
commit883e4dd62bb260c4d3f05b25c860051860065867 (patch)
tree59798f416ce119fa90229c6ae8a8541a88b1af37
parent5b0e68131d480ef54e25af98f09269952976e48e (diff)
downloadNetworkManager-th/nm-config-intern-bgo750558.tar.gz
config/test: add test for set_values()th/nm-config-intern-bgo750558
-rw-r--r--src/tests/config/test-config.c366
1 files changed, 356 insertions, 10 deletions
diff --git a/src/tests/config/test-config.c b/src/tests/config/test-config.c
index d259b620bb..33b66d614f 100644
--- a/src/tests/config/test-config.c
+++ b/src/tests/config/test-config.c
@@ -32,8 +32,27 @@
#include "nm-test-utils.h"
+/********************************************************************************/
+
+static void
+_assert_config_value (const NMConfigData *config_data, const char *group, const char *key, const char *expected_value, const char *file, int line)
+{
+ gs_free char *value = NULL;
+
+ value = nm_config_data_get_value (config_data, group, key, NM_CONFIG_GET_VALUE_NONE);
+ if (g_strcmp0 (value, expected_value)) {
+ g_error ("(%s:%d) invalid value in config-data %s.%s = %s%s%s (instead of %s%s%s)",
+ file, line, group, key,
+ NM_PRINT_FMT_QUOTED (value, "\"", value, "\"", "(null)"),
+ NM_PRINT_FMT_QUOTED (expected_value, "\"", expected_value, "\"", "(null)"));
+ }
+}
+#define assert_config_value(config_data, group, key, expected_value) _assert_config_value (config_data, group, key, expected_value, __FILE__, __LINE__)
+
+/********************************************************************************/
+
static NMConfig *
-setup_config (GError **error, const char *config_file, const char *intern_config, const char *config_dir, const char *system_config_dir, ...)
+setup_config (GError **error, const char *config_file, const char *intern_config, const char *const* atomic_section_prefixes, const char *config_dir, const char *system_config_dir, ...)
{
va_list ap;
GPtrArray *args;
@@ -82,7 +101,7 @@ setup_config (GError **error, const char *config_file, const char *intern_config
g_ptr_array_free (args, TRUE);
- config = nm_config_setup (cli, NULL, &local_error);
+ config = nm_config_setup (cli, (char **) atomic_section_prefixes, &local_error);
if (error) {
g_assert (!config);
g_assert (local_error);
@@ -105,7 +124,7 @@ test_config_simple (void)
gs_unref_object NMDevice *dev51 = nm_test_device_new ("00:00:00:00:00:51");
gs_unref_object NMDevice *dev52 = nm_test_device_new ("00:00:00:00:00:52");
- config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", "/no/such/dir", "", NULL);
+ config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", NULL, "/no/such/dir", "", NULL);
g_assert_cmpstr (nm_config_data_get_config_main_file (nm_config_get_data_orig (config)), ==, SRCDIR "/NetworkManager.conf");
g_assert_cmpstr (nm_config_get_dhcp_client (config), ==, "dhclient");
@@ -184,7 +203,7 @@ test_config_non_existent (void)
{
GError *error = NULL;
- setup_config (&error, SRCDIR "/no-such-file", "", "/no/such/dir", "", NULL);
+ setup_config (&error, SRCDIR "/no-such-file", "", NULL, "/no/such/dir", "", NULL);
g_assert_error (error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_NOT_FOUND);
g_clear_error (&error);
}
@@ -194,7 +213,7 @@ test_config_parse_error (void)
{
GError *error = NULL;
- setup_config (&error, SRCDIR "/bad.conf", "", "/no/such/dir", "", NULL);
+ setup_config (&error, SRCDIR "/bad.conf", "", NULL, "/no/such/dir", "", NULL);
g_assert_error (error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_PARSE);
g_clear_error (&error);
}
@@ -205,7 +224,7 @@ test_config_override (void)
NMConfig *config;
const char **plugins;
- config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", "/no/such/dir", "",
+ config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", NULL, "/no/such/dir", "",
"--plugins", "alpha,beta,gamma,delta",
"--connectivity-interval", "12",
NULL);
@@ -243,7 +262,7 @@ test_config_no_auto_default (void)
g_assert_cmpint (nwrote, ==, 18);
close (fd);
- config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", "/no/such/dir", "",
+ config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", NULL, "/no/such/dir", "",
"--no-auto-default", state_file,
NULL);
@@ -265,7 +284,7 @@ test_config_no_auto_default (void)
g_object_unref (config);
- config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", "/no/such/dir", "",
+ config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", NULL, "/no/such/dir", "",
"--no-auto-default", state_file,
NULL);
@@ -293,7 +312,7 @@ test_config_confdir (void)
char *value;
GSList *specs;
- config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", SRCDIR "/conf.d", "", NULL);
+ config = setup_config (NULL, SRCDIR "/NetworkManager.conf", "", NULL, SRCDIR "/conf.d", "", NULL);
g_assert_cmpstr (nm_config_data_get_config_main_file (nm_config_get_data_orig (config)), ==, SRCDIR "/NetworkManager.conf");
g_assert_cmpstr (nm_config_get_dhcp_client (config), ==, "dhcpcd");
@@ -399,11 +418,336 @@ test_config_confdir_parse_error (void)
GError *error = NULL;
/* Using SRCDIR as the conf dir will pick up bad.conf */
- setup_config (&error, SRCDIR "/NetworkManager.conf", "", SRCDIR, "", NULL);
+ setup_config (&error, SRCDIR "/NetworkManager.conf", "", NULL, SRCDIR, "", NULL);
g_assert_error (error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_PARSE);
g_clear_error (&error);
}
+/*****************************************************************************/
+
+typedef void (*TestSetValuesUserSetFcn) (NMConfig *config, gboolean is_user, GKeyFile *keyfile_user, NMConfigChangeFlags *out_expected_changes);
+typedef void (*TestSetValuesCheckStateFcn) (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data);
+
+typedef struct {
+ NMConfigChangeFlags changes;
+ TestSetValuesCheckStateFcn check_state_fcn;
+} TestSetValuesConfigChangedData;
+
+static void
+_set_values_config_changed_cb (NMConfig *config,
+ NMConfigData *config_data,
+ NMConfigChangeFlags changes,
+ NMConfigData *old_data,
+ TestSetValuesConfigChangedData *config_changed_data)
+{
+ g_assert (changes != NM_CONFIG_CHANGE_NONE);
+ g_assert (config_changed_data);
+ g_assert (config_changed_data->changes == NM_CONFIG_CHANGE_NONE);
+
+ if (changes == NM_CONFIG_CHANGE_SIGHUP)
+ return;
+ changes &= ~NM_CONFIG_CHANGE_SIGHUP;
+
+ config_changed_data->changes = changes;
+
+ if (config_changed_data->check_state_fcn)
+ config_changed_data->check_state_fcn (config, config_data, TRUE, changes, old_data);
+}
+
+static void
+_set_values_user (NMConfig *config,
+ const char *CONFIG_USER,
+ TestSetValuesUserSetFcn set_fcn,
+ TestSetValuesCheckStateFcn check_state_fcn)
+{
+ GKeyFile *keyfile_user;
+ gboolean success;
+ gs_free_error GError *error = NULL;
+ TestSetValuesConfigChangedData config_changed_data = {
+ .changes = NM_CONFIG_CHANGE_NONE,
+ .check_state_fcn = check_state_fcn,
+ };
+ NMConfigChangeFlags expected_changes = NM_CONFIG_CHANGE_NONE;
+ gs_unref_object NMConfigData *config_data_before = NULL;
+
+ keyfile_user = nm_config_create_keyfile ();
+
+ success = g_key_file_load_from_file (keyfile_user, CONFIG_USER, G_KEY_FILE_NONE, &error);
+ nmtst_assert_success (success, error);
+
+ if (set_fcn)
+ set_fcn (config, TRUE, keyfile_user, &expected_changes);
+
+ success = g_key_file_save_to_file (keyfile_user, CONFIG_USER, &error);
+ nmtst_assert_success (success, error);
+
+ g_signal_connect (G_OBJECT (config),
+ NM_CONFIG_SIGNAL_CONFIG_CHANGED,
+ G_CALLBACK (_set_values_config_changed_cb),
+ &config_changed_data);
+
+ config_data_before = g_object_ref (nm_config_get_data (config));
+
+ if (expected_changes != NM_CONFIG_CHANGE_NONE)
+ g_test_expect_message ("NetworkManager", G_LOG_LEVEL_MESSAGE, "*config: update *");
+ else
+ g_test_expect_message ("NetworkManager", G_LOG_LEVEL_MESSAGE, "*config: signal SIGHUP (no changes from disk)*");
+
+ nm_config_reload (config, SIGHUP);
+
+ g_test_assert_expected_messages ();
+
+ g_assert (expected_changes == config_changed_data.changes);
+
+ if (check_state_fcn)
+ check_state_fcn (config, nm_config_get_data (config), FALSE, NM_CONFIG_CHANGE_NONE, config_data_before);
+
+ g_signal_handlers_disconnect_by_func (config, _set_values_config_changed_cb, &config_changed_data);
+
+ g_key_file_unref (keyfile_user);
+}
+
+static void
+_set_values_intern (NMConfig *config,
+ TestSetValuesUserSetFcn set_fcn,
+ TestSetValuesCheckStateFcn check_state_fcn)
+{
+ GKeyFile *keyfile_intern;
+ TestSetValuesConfigChangedData config_changed_data = {
+ .changes = NM_CONFIG_CHANGE_NONE,
+ .check_state_fcn = check_state_fcn,
+ };
+ NMConfigChangeFlags expected_changes = NM_CONFIG_CHANGE_NONE;
+ gs_unref_object NMConfigData *config_data_before = NULL;
+
+ config_data_before = g_object_ref (nm_config_get_data (config));
+
+ keyfile_intern = nm_config_data_clone_keyfile_intern (config_data_before);
+
+ if (set_fcn)
+ set_fcn (config, FALSE, keyfile_intern, &expected_changes);
+
+ g_signal_connect (G_OBJECT (config),
+ NM_CONFIG_SIGNAL_CONFIG_CHANGED,
+ G_CALLBACK (_set_values_config_changed_cb),
+ &config_changed_data);
+
+ if (expected_changes != NM_CONFIG_CHANGE_NONE)
+ g_test_expect_message ("NetworkManager", G_LOG_LEVEL_MESSAGE, "*config: update *");
+
+ nm_config_set_values (config, keyfile_intern, TRUE, FALSE);
+
+ g_test_assert_expected_messages ();
+
+ g_assert (expected_changes == config_changed_data.changes);
+
+ if (check_state_fcn)
+ check_state_fcn (config, nm_config_get_data (config), FALSE, NM_CONFIG_CHANGE_NONE, config_data_before);
+
+ g_signal_handlers_disconnect_by_func (config, _set_values_config_changed_cb, &config_changed_data);
+
+ g_key_file_unref (keyfile_intern);
+}
+
+static void
+_set_values_user_intern_section_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ g_key_file_set_string (keyfile, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"section1", "key", "this-should-be-ignored");
+}
+
+static void
+_set_values_user_intern_section_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ g_assert (changes == NM_CONFIG_CHANGE_NONE);
+ g_assert (!nm_config_data_has_group (config_data, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"section1"));
+}
+
+static void
+_set_values_user_initial_values_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ g_key_file_remove_group (keyfile, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"section1", NULL);
+ g_key_file_set_string (keyfile, "section1", "key1", "value1");
+ *out_expected_changes = NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_USER;
+}
+
+static void
+_set_values_user_initial_values_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ if (is_change_event)
+ g_assert (changes == (NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_USER));
+ assert_config_value (config_data, "section1", "key1", "value1");
+}
+
+static void
+_set_values_intern_internal_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ g_key_file_set_string (keyfile, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"section1", "key", "internal-section");
+ *out_expected_changes = NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_INTERN;
+}
+
+static void
+_set_values_intern_internal_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ if (is_change_event)
+ g_assert (changes == (NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_INTERN));
+ assert_config_value (config_data, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"section1", "key", "internal-section");
+}
+
+static void
+_set_values_user_atomic_section_1_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", "key1", "user-value1");
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", "key2", "user-value2");
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-b", "key1", "user-value1");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key1", "user-value1");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key2", "user-value2");
+ *out_expected_changes = NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_USER;
+}
+
+static void
+_set_values_user_atomic_section_1_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ if (is_change_event)
+ g_assert (changes == (NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_USER));
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key1", "user-value1");
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key2", "user-value2");
+ assert_config_value (config_data, "atomic-prefix-1.section-b", "key1", "user-value1");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key1", "user-value1");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key2", "user-value2");
+}
+
+static void
+_set_values_intern_atomic_section_1_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", "key1", "intern-value1");
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", "key3", "intern-value3");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key1", "intern-value1");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key3", "intern-value3");
+ *out_expected_changes = NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_INTERN;
+}
+
+static void
+_set_values_intern_atomic_section_1_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ if (is_change_event)
+ g_assert (changes == (NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_INTERN));
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key1", "intern-value1");
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key2", NULL);
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key3", "intern-value3");
+ assert_config_value (config_data, "atomic-prefix-1.section-b", "key1", "user-value1");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key1", "intern-value1");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key2", "user-value2");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key3", "intern-value3");
+ g_assert ( nm_config_data_is_intern_atomic_group (config_data, "atomic-prefix-1.section-a"));
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "atomic-prefix-1.section-b"));
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "non-atomic-prefix-1.section-a"));
+}
+
+static void
+_set_values_user_atomic_section_2_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", "key1", "user-value1-x");
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", "key2", "user-value2");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key1", "user-value1-x");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key2", "user-value2-x");
+ *out_expected_changes = NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_USER | NM_CONFIG_CHANGE_VALUES_INTERN;
+}
+
+static void
+_set_values_user_atomic_section_2_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ if (is_change_event)
+ g_assert (changes == (NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_USER | NM_CONFIG_CHANGE_VALUES_INTERN));
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key1", "user-value1-x");
+ assert_config_value (config_data, "atomic-prefix-1.section-a", "key2", "user-value2");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key1", "user-value1-x");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key2", "user-value2-x");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key3", "intern-value3");
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "atomic-prefix-1.section-a"));
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "atomic-prefix-1.section-b"));
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "non-atomic-prefix-1.section-a"));
+}
+
+static void
+_set_values_intern_atomic_section_2_set (NMConfig *config, gboolean set_user, GKeyFile *keyfile, NMConfigChangeFlags *out_expected_changes)
+{
+ /* let's hide an atomic section and one key. */
+ g_key_file_set_string (keyfile, "atomic-prefix-1.section-a", NM_CONFIG_KEYFILE_KEY_ATOMIC_SECTION_WAS, "any-value");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", NM_CONFIG_KEYFILE_KEYPREFIX_WAS"nap1-key1", "any-value");
+ g_key_file_set_string (keyfile, "non-atomic-prefix-1.section-a", "nap1-key3", "intern-value3");
+ g_key_file_set_string (keyfile, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"with-whitespace", "key1", " b c\\, d ");
+ g_key_file_set_value (keyfile, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"with-whitespace", "key2", " b c\\, d ");
+ *out_expected_changes = NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_INTERN;
+}
+
+static void
+_set_values_intern_atomic_section_2_check (NMConfig *config, NMConfigData *config_data, gboolean is_change_event, NMConfigChangeFlags changes, NMConfigData *old_data)
+{
+ if (is_change_event)
+ g_assert (changes == (NM_CONFIG_CHANGE_VALUES | NM_CONFIG_CHANGE_VALUES_INTERN));
+ g_assert (!nm_config_data_has_group (config_data, "atomic-prefix-1.section-a"));
+ assert_config_value (config_data, "atomic-prefix-1.section-b", "key1", "user-value1");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key1", NULL);
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key2", "user-value2-x");
+ assert_config_value (config_data, "non-atomic-prefix-1.section-a", "nap1-key3", "intern-value3");
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "atomic-prefix-1.section-a"));
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "atomic-prefix-1.section-b"));
+ g_assert (!nm_config_data_is_intern_atomic_group (config_data, "non-atomic-prefix-1.section-a"));
+ assert_config_value (config_data, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"with-whitespace", "key1", " b c\\, d ");
+ assert_config_value (config_data, NM_CONFIG_KEYFILE_GROUPPREFIX_INTERN"with-whitespace", "key2", " b c\\, d ");
+}
+
+static void
+test_config_set_values (void)
+{
+ gs_unref_object NMConfig *config = NULL;
+ const char *CONFIG_USER = SRCDIR"/test-set-values-user.conf";
+ const char *CONFIG_INTERN = SRCDIR"/test-set-values-intern.conf";
+ const char *atomic_section_prefixes[] = {
+ "atomic-prefix-1.",
+ "atomic-prefix-2.",
+ NULL,
+ };
+
+ g_assert (g_file_set_contents (CONFIG_USER, "", 0, NULL));
+ g_assert (g_file_set_contents (CONFIG_INTERN, "", 0, NULL));
+
+ config = setup_config (NULL, CONFIG_USER, CONFIG_INTERN, atomic_section_prefixes, "", "", NULL);
+
+ _set_values_user (config, CONFIG_USER,
+ _set_values_user_intern_section_set,
+ _set_values_user_intern_section_check);
+
+ _set_values_user (config, CONFIG_USER,
+ _set_values_user_initial_values_set,
+ _set_values_user_initial_values_check);
+
+ _set_values_intern (config,
+ _set_values_intern_internal_set,
+ _set_values_intern_internal_check);
+
+ _set_values_user (config, CONFIG_USER,
+ _set_values_user_atomic_section_1_set,
+ _set_values_user_atomic_section_1_check);
+
+ _set_values_intern (config,
+ _set_values_intern_atomic_section_1_set,
+ _set_values_intern_atomic_section_1_check);
+
+ _set_values_user (config, CONFIG_USER,
+ _set_values_user_atomic_section_2_set,
+ _set_values_user_atomic_section_2_check);
+
+ _set_values_intern (config,
+ _set_values_intern_atomic_section_2_set,
+ _set_values_intern_atomic_section_2_check);
+
+ g_assert (remove (CONFIG_USER) == 0);
+ g_assert (remove (CONFIG_INTERN) == 0);
+}
+
+/*****************************************************************************/
+
NMTST_DEFINE ();
int
@@ -427,6 +771,8 @@ main (int argc, char **argv)
g_test_add_func ("/config/confdir", test_config_confdir);
g_test_add_func ("/config/confdir-parse-error", test_config_confdir_parse_error);
+ g_test_add_func ("/config/set-values", test_config_set_values);
+
/* This one has to come last, because it leaves its values in
* nm-config.c's global variables, and there's no way to reset
* those to NULL.