mirror of
https://git.proxmox.com/git/libgit2
synced 2025-08-07 07:52:30 +00:00
config: test all multivars are updated
If a multivar exists within two sections (of the same name) then they should both be updated in a `set_multivar`. Ensure that this is the case.
This commit is contained in:
parent
0daf998de7
commit
d6b7e40497
@ -230,12 +230,24 @@ void test_config_write__overwrite_value_with_duplicate_header(void)
|
|||||||
git_config_free(cfg);
|
git_config_free(cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int multivar_cb(const git_config_entry *entry, void *data)
|
||||||
|
{
|
||||||
|
int *n = (int *)data;
|
||||||
|
|
||||||
|
cl_assert_equal_s(entry->value, "newurl");
|
||||||
|
|
||||||
|
(*n)++;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
void test_config_write__overwrite_multivar_within_duplicate_header(void)
|
void test_config_write__overwrite_multivar_within_duplicate_header(void)
|
||||||
{
|
{
|
||||||
const char *file_name = "config-duplicate-header";
|
const char *file_name = "config-duplicate-header";
|
||||||
const char *entry_name = "remote.origin.url";
|
const char *entry_name = "remote.origin.url";
|
||||||
git_config *cfg;
|
git_config *cfg;
|
||||||
git_config_entry *entry;
|
git_config_entry *entry;
|
||||||
|
int n = 0;
|
||||||
|
|
||||||
/* This config can occur after removing and re-adding the origin remote */
|
/* This config can occur after removing and re-adding the origin remote */
|
||||||
const char *file_content =
|
const char *file_content =
|
||||||
@ -253,17 +265,15 @@ void test_config_write__overwrite_multivar_within_duplicate_header(void)
|
|||||||
|
|
||||||
/* Update that entry */
|
/* Update that entry */
|
||||||
cl_git_pass(git_config_set_multivar(cfg, entry_name, ".*", "newurl"));
|
cl_git_pass(git_config_set_multivar(cfg, entry_name, ".*", "newurl"));
|
||||||
|
|
||||||
/* Reopen the file and make sure the entry was updated */
|
|
||||||
git_config_entry_free(entry);
|
git_config_entry_free(entry);
|
||||||
git_config_free(cfg);
|
git_config_free(cfg);
|
||||||
cl_git_pass(git_config_open_ondisk(&cfg, file_name));
|
|
||||||
cl_git_pass(git_config_get_entry(&entry, cfg, entry_name));
|
|
||||||
|
|
||||||
cl_assert_equal_s("newurl", entry->value);
|
/* Reopen the file and make sure the entry was updated */
|
||||||
|
cl_git_pass(git_config_open_ondisk(&cfg, file_name));
|
||||||
|
cl_git_pass(git_config_get_multivar_foreach(cfg, entry_name, NULL, multivar_cb, &n));
|
||||||
|
cl_assert_equal_i(2, n);
|
||||||
|
|
||||||
/* Cleanup */
|
/* Cleanup */
|
||||||
git_config_entry_free(entry);
|
|
||||||
git_config_free(cfg);
|
git_config_free(cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user