Blame tests/config/snapshot.c

Packit Service 20376f
#include "clar_libgit2.h"
Packit Service 20376f
Packit Service 20376f
void test_config_snapshot__create_snapshot(void)
Packit Service 20376f
{
Packit Service 20376f
	int32_t tmp;
Packit Service 20376f
	git_config *cfg, *snapshot, *new_snapshot;
Packit Service 20376f
	const char *filename = "config-ext-change";
Packit Service 20376f
Packit Service 20376f
	cl_git_mkfile(filename, "[old]\nvalue = 5\n");
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_open_ondisk(&cfg, filename));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_get_int32(&tmp, cfg, "old.value"));
Packit Service 20376f
	cl_assert_equal_i(5, tmp);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_snapshot(&snapshot, cfg));
Packit Service 20376f
Packit Service 20376f
	/* Change the value on the file itself (simulate external process) */
Packit Service 20376f
	cl_git_mkfile(filename, "[old]\nvalue = 56\n");
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_get_int32(&tmp, cfg, "old.value"));
Packit Service 20376f
	cl_assert_equal_i(56, tmp);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_get_int32(&tmp, snapshot, "old.value"));
Packit Service 20376f
	cl_assert_equal_i(5, tmp);
Packit Service 20376f
Packit Service 20376f
	/* Change the value on the file itself (simulate external process) */
Packit Service 20376f
	cl_git_mkfile(filename, "[old]\nvalue = 999\n");
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_snapshot(&new_snapshot, cfg));
Packit Service 20376f
Packit Service 20376f
	/* New snapshot should see new value */
Packit Service 20376f
	cl_git_pass(git_config_get_int32(&tmp, new_snapshot, "old.value"));
Packit Service 20376f
	cl_assert_equal_i(999, tmp);
Packit Service 20376f
Packit Service 20376f
	/* Old snapshot should still have the old value */
Packit Service 20376f
	cl_git_pass(git_config_get_int32(&tmp, snapshot, "old.value"));
Packit Service 20376f
	cl_assert_equal_i(5, tmp);
Packit Service 20376f
	
Packit Service 20376f
	git_config_free(new_snapshot);
Packit Service 20376f
	git_config_free(snapshot);
Packit Service 20376f
	git_config_free(cfg);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
static int count_me(const git_config_entry *entry, void *payload)
Packit Service 20376f
{
Packit Service 20376f
	int *n = (int *) payload;
Packit Service 20376f
Packit Service 20376f
	GIT_UNUSED(entry);
Packit Service 20376f
Packit Service 20376f
	(*n)++;
Packit Service 20376f
Packit Service 20376f
	return 0;
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_config_snapshot__multivar(void)
Packit Service 20376f
{
Packit Service 20376f
	int count = 0;
Packit Service 20376f
	git_config *cfg, *snapshot;
Packit Service 20376f
	const char *filename = "config-file";
Packit Service 20376f
Packit Service 20376f
	cl_git_mkfile(filename, "[old]\nvalue = 5\nvalue = 6\n");
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_open_ondisk(&cfg, filename));
Packit Service 20376f
	cl_git_pass(git_config_get_multivar_foreach(cfg, "old.value", NULL, count_me, &count));
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_i(2, count);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_config_snapshot(&snapshot, cfg));
Packit Service 20376f
	git_config_free(cfg);
Packit Service 20376f
Packit Service 20376f
	count = 0;
Packit Service 20376f
	cl_git_pass(git_config_get_multivar_foreach(snapshot, "old.value", NULL, count_me, &count));
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_i(2, count);
Packit Service 20376f
Packit Service 20376f
	git_config_free(snapshot);
Packit Service 20376f
}