Commit 6a05c7a0 by Edward Thomson

threads::refdb tests: use new threaded clar assert

parent bbf22f82
...@@ -22,6 +22,7 @@ void test_threads_refdb__cleanup(void) ...@@ -22,6 +22,7 @@ void test_threads_refdb__cleanup(void)
#define NREFS 10 #define NREFS 10
struct th_data { struct th_data {
cl_git_thread_err error;
int id; int id;
const char *path; const char *path;
}; };
...@@ -34,11 +35,11 @@ static void *iterate_refs(void *arg) ...@@ -34,11 +35,11 @@ static void *iterate_refs(void *arg)
int count = 0, error; int count = 0, error;
git_repository *repo; git_repository *repo;
cl_git_pass(git_repository_open(&repo, data->path)); cl_git_thread_pass(data, git_repository_open(&repo, data->path));
do { do {
error = git_reference_iterator_new(&i, repo); error = git_reference_iterator_new(&i, repo);
} while (error == GIT_ELOCKED); } while (error == GIT_ELOCKED);
cl_git_pass(error); cl_git_thread_pass(data, error);
for (count = 0; !git_reference_next(&ref, i); ++count) { for (count = 0; !git_reference_next(&ref, i); ++count) {
cl_assert(ref != NULL); cl_assert(ref != NULL);
...@@ -64,26 +65,27 @@ static void *create_refs(void *arg) ...@@ -64,26 +65,27 @@ static void *create_refs(void *arg)
git_reference *ref[NREFS]; git_reference *ref[NREFS];
git_repository *repo; git_repository *repo;
cl_git_pass(git_repository_open(&repo, data->path)); cl_git_thread_pass(data, git_repository_open(&repo, data->path));
do { do {
error = git_reference_name_to_id(&head, repo, "HEAD"); error = git_reference_name_to_id(&head, repo, "HEAD");
} while (error == GIT_ELOCKED); } while (error == GIT_ELOCKED);
cl_git_pass(error); cl_git_thread_pass(data, error);
for (i = 0; i < NREFS; ++i) { for (i = 0; i < NREFS; ++i) {
p_snprintf(name, sizeof(name), "refs/heads/thread-%03d-%02d", data->id, i); p_snprintf(name, sizeof(name), "refs/heads/thread-%03d-%02d", data->id, i);
do { do {
error = git_reference_create(&ref[i], repo, name, &head, 0, NULL); error = git_reference_create(&ref[i], repo, name, &head, 0, NULL);
} while (error == GIT_ELOCKED); } while (error == GIT_ELOCKED);
cl_git_pass(error); cl_git_thread_pass(data, error);
if (i == NREFS/2) { if (i == NREFS/2) {
git_refdb *refdb; git_refdb *refdb;
cl_git_pass(git_repository_refdb(&refdb, repo)); cl_git_thread_pass(data, git_repository_refdb(&refdb, repo));
do { do {
error = git_refdb_compress(refdb); error = git_refdb_compress(refdb);
} while (error == GIT_ELOCKED); } while (error == GIT_ELOCKED);
cl_git_thread_pass(data, error);
git_refdb_free(refdb); git_refdb_free(refdb);
} }
} }
...@@ -105,7 +107,7 @@ static void *delete_refs(void *arg) ...@@ -105,7 +107,7 @@ static void *delete_refs(void *arg)
char name[128]; char name[128];
git_repository *repo; git_repository *repo;
cl_git_pass(git_repository_open(&repo, data->path)); cl_git_thread_pass(data, git_repository_open(&repo, data->path));
for (i = 0; i < NREFS; ++i) { for (i = 0; i < NREFS; ++i) {
p_snprintf( p_snprintf(
...@@ -119,17 +121,17 @@ static void *delete_refs(void *arg) ...@@ -119,17 +121,17 @@ static void *delete_refs(void *arg)
if (error == GIT_ENOTFOUND) if (error == GIT_ENOTFOUND)
error = 0; error = 0;
cl_git_pass(error); cl_git_thread_pass(data, error);
git_reference_free(ref); git_reference_free(ref);
} }
if (i == NREFS/2) { if (i == NREFS/2) {
git_refdb *refdb; git_refdb *refdb;
cl_git_pass(git_repository_refdb(&refdb, repo)); cl_git_thread_pass(data, git_repository_refdb(&refdb, repo));
do { do {
error = git_refdb_compress(refdb); error = git_refdb_compress(refdb);
} while (error == GIT_ELOCKED); } while (error == GIT_ELOCKED);
cl_git_pass(error); cl_git_thread_pass(data, error);
git_refdb_free(refdb); git_refdb_free(refdb);
} }
} }
...@@ -194,6 +196,7 @@ void test_threads_refdb__edit_while_iterate(void) ...@@ -194,6 +196,7 @@ void test_threads_refdb__edit_while_iterate(void)
#ifdef GIT_THREADS #ifdef GIT_THREADS
for (t = 0; t < THREADS; ++t) { for (t = 0; t < THREADS; ++t) {
cl_git_pass(git_thread_join(&th[t], NULL)); cl_git_pass(git_thread_join(&th[t], NULL));
cl_git_thread_check(&th_data[t]);
} }
memset(th, 0, sizeof(th)); memset(th, 0, sizeof(th));
...@@ -205,6 +208,7 @@ void test_threads_refdb__edit_while_iterate(void) ...@@ -205,6 +208,7 @@ void test_threads_refdb__edit_while_iterate(void)
for (t = 0; t < THREADS; ++t) { for (t = 0; t < THREADS; ++t) {
cl_git_pass(git_thread_join(&th[t], NULL)); cl_git_pass(git_thread_join(&th[t], NULL));
cl_git_thread_check(&th_data[t]);
} }
#endif #endif
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment