diff options
| author | Russell Belfer <arrbee@arrbee.com> | 2012-02-29 12:04:59 -0800 | 
|---|---|---|
| committer | Russell Belfer <arrbee@arrbee.com> | 2012-03-02 15:51:55 -0800 | 
| commit | 854eccbb2d86c2910f9d98dc52f9ebd0e37c262a (patch) | |
| tree | b22048a02480598477cde9c41fc16d3967226d6b /tests-clar/clar_helpers.c | |
| parent | 74fa4bfae37e9d7c9e35550c881b114d7a83c4fa (diff) | |
| download | libgit2-854eccbb2d86c2910f9d98dc52f9ebd0e37c262a.tar.gz | |
Clean up GIT_UNUSED macros on all platforms
It turns out that commit 31e9cfc4cbcaf1b38cdd3dbe3282a8f57e5366a5
did not fix the GIT_USUSED behavior on all platforms.  This commit
walks through and really cleans things up more thoroughly, getting
rid of the unnecessary stuff.
To remove the use of some GIT_UNUSED, I ended up adding a couple
of new iterators for hashtables that allow you to iterator just
over keys or just over values.
In making this change, I found a bug in the clar tests (where we
were doing *count++ but meant to do (*count)++ to increment the
value).  I fixed that but then found the test failing because it
was not really using an empty repo.  So, I took some of the code
that I wrote for iterator testing and moved it to clar_helpers.c,
then made use of that to make it easier to open fixtures on a
per test basis even within a single test file.
Diffstat (limited to 'tests-clar/clar_helpers.c')
| -rw-r--r-- | tests-clar/clar_helpers.c | 49 | 
1 files changed, 49 insertions, 0 deletions
| diff --git a/tests-clar/clar_helpers.c b/tests-clar/clar_helpers.c index 1ef5a9bf2..22db56f0c 100644 --- a/tests-clar/clar_helpers.c +++ b/tests-clar/clar_helpers.c @@ -39,3 +39,52 @@ void cl_git_append2file(const char *filename, const char *new_content)  	cl_must_pass(p_chmod(filename, 0644));  } +static const char *_cl_sandbox = NULL; +static git_repository *_cl_repo = NULL; + +git_repository *cl_git_sandbox_init(const char *sandbox) +{ +	/* Copy the whole sandbox folder from our fixtures to our test sandbox +	 * area.  After this it can be accessed with `./sandbox` +	 */ +	cl_fixture_sandbox(sandbox); +	_cl_sandbox = sandbox; + +	p_chdir(sandbox); + +	/* Rename `sandbox/.gitted` to `sandbox/.git` which must be done since +	 * we cannot store a folder named `.git` inside the fixtures folder of +	 * our libgit2 repo. +	 */ +	cl_git_pass(p_rename(".gitted", ".git")); + +	/* If we have `gitattributes`, rename to `.gitattributes`.  This may +	 * be necessary if we don't want the attributes to be applied in the +	 * libgit2 repo, but just during testing. +	 */ +	if (p_access("gitattributes", F_OK) == 0) +		cl_git_pass(p_rename("gitattributes", ".gitattributes")); + +	/* As with `gitattributes`, we may need `gitignore` just for testing. */ +	if (p_access("gitignore", F_OK) == 0) +		cl_git_pass(p_rename("gitignore", ".gitignore")); + +	p_chdir(".."); + +	/* Now open the sandbox repository and make it available for tests */ +	cl_git_pass(git_repository_open(&_cl_repo, sandbox)); + +	return _cl_repo; +} + +void cl_git_sandbox_cleanup(void) +{ +	if (_cl_repo) { +		git_repository_free(_cl_repo); +		_cl_repo = NULL; +	} +	if (_cl_sandbox) { +		cl_fixture_cleanup(_cl_sandbox); +		_cl_sandbox = NULL; +	} +} | 
