diff options
| author | Carlos Martín Nieto <cmn@dwim.me> | 2015-04-21 22:10:36 +0200 | 
|---|---|---|
| committer | Carlos Martín Nieto <cmn@dwim.me> | 2015-05-13 09:46:35 +0200 | 
| commit | 8f0104ecc54db00a075310ab744a19eb60e3d740 (patch) | |
| tree | 775b3237a853c556a4d44840fc6c562e7b114415 /tests | |
| parent | 05259114427234831cf4915cbe40a5bb8ea021b0 (diff) | |
| download | libgit2-8f0104ecc54db00a075310ab744a19eb60e3d740.tar.gz | |
Remove the callbacks struct from the remote
Having the setting be different from calling its actions was not a great
idea and made for the sake of the wrong convenience.
Instead of that, accept either fetch options, push options or the
callbacks when dealing with the remote. The fetch options are currently
only the callbacks, but more options will be moved from setters and
getters on the remote to the options.
This does mean passing the same struct along the different functions but
the typical use-case will only call git_remote_fetch() or
git_remote_push() and so won't notice much difference.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/checkout/index.c | 4 | ||||
| -rw-r--r-- | tests/clone/empty.c | 4 | ||||
| -rw-r--r-- | tests/clone/nonetwork.c | 6 | ||||
| -rw-r--r-- | tests/fetchhead/nonetwork.c | 2 | ||||
| -rw-r--r-- | tests/network/fetchlocal.c | 117 | ||||
| -rw-r--r-- | tests/network/remote/defaultbranch.c | 6 | ||||
| -rw-r--r-- | tests/network/remote/local.c | 47 | ||||
| -rw-r--r-- | tests/network/remote/remotes.c | 10 | ||||
| -rw-r--r-- | tests/online/clone.c | 61 | ||||
| -rw-r--r-- | tests/online/fetch.c | 54 | ||||
| -rw-r--r-- | tests/online/fetchhead.c | 9 | ||||
| -rw-r--r-- | tests/online/push.c | 20 | ||||
| -rw-r--r-- | tests/submodule/update.c | 4 | 
13 files changed, 140 insertions, 204 deletions
| diff --git a/tests/checkout/index.c b/tests/checkout/index.c index b759db206..de0770dba 100644 --- a/tests/checkout/index.c +++ b/tests/checkout/index.c @@ -154,9 +154,7 @@ void test_checkout_index__honor_coresymlinks_default(void)  	cl_git_pass(git_repository_set_workdir(repo, "symlink", 1));  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	cl_git_pass(git_remote_connect(origin, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(origin, NULL)); -	cl_git_pass(git_remote_update_tips(origin, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, NULL, NULL));  	git_remote_free(origin);  	cl_git_pass(git_revparse_single(&target, repo, "remotes/origin/master")); diff --git a/tests/clone/empty.c b/tests/clone/empty.c index 8f6071096..2a6217580 100644 --- a/tests/clone/empty.c +++ b/tests/clone/empty.c @@ -10,14 +10,14 @@ static git_repository *g_repo_cloned;  void test_clone_empty__initialize(void)  {  	git_repository *sandbox = cl_git_sandbox_init("empty_bare.git"); -	git_remote_callbacks dummy_callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options dummy_options = GIT_FETCH_OPTIONS_INIT;  	cl_git_remove_placeholders(git_repository_path(sandbox), "dummy-marker.txt");  	g_repo = NULL;  	memset(&g_options, 0, sizeof(git_clone_options));  	g_options.version = GIT_CLONE_OPTIONS_VERSION; -	g_options.remote_callbacks = dummy_callbacks; +	g_options.fetch_opts = dummy_options;  }  void test_clone_empty__cleanup(void) diff --git a/tests/clone/nonetwork.c b/tests/clone/nonetwork.c index e4794fc14..fec6aff2e 100644 --- a/tests/clone/nonetwork.c +++ b/tests/clone/nonetwork.c @@ -15,7 +15,7 @@ static git_remote* g_remote;  void test_clone_nonetwork__initialize(void)  {  	git_checkout_options dummy_opts = GIT_CHECKOUT_OPTIONS_INIT; -	git_remote_callbacks dummy_callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options dummy_fetch = GIT_FETCH_OPTIONS_INIT;  	g_repo = NULL; @@ -23,7 +23,7 @@ void test_clone_nonetwork__initialize(void)  	g_options.version = GIT_CLONE_OPTIONS_VERSION;  	g_options.checkout_opts = dummy_opts;  	g_options.checkout_opts.checkout_strategy = GIT_CHECKOUT_SAFE; -	g_options.remote_callbacks = dummy_callbacks; +	g_options.fetch_opts = dummy_fetch;  }  void test_clone_nonetwork__cleanup(void) @@ -179,7 +179,7 @@ void test_clone_nonetwork__can_cancel_clone_in_fetch(void)  {  	g_options.checkout_branch = "test"; -	g_options.remote_callbacks.transfer_progress = +	g_options.fetch_opts.callbacks.transfer_progress =  		clone_cancel_fetch_transfer_progress_cb;  	cl_git_fail_with(git_clone( diff --git a/tests/fetchhead/nonetwork.c b/tests/fetchhead/nonetwork.c index 2d6d53eb6..489481826 100644 --- a/tests/fetchhead/nonetwork.c +++ b/tests/fetchhead/nonetwork.c @@ -335,7 +335,7 @@ void test_fetchhead_nonetwork__unborn_with_upstream(void)  	cl_git_pass(git_remote_set_url(remote, cl_fixture("testrepo.git")));  	cl_git_pass(git_remote_save(remote)); -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, NULL, NULL));  	git_remote_free(remote);  	cl_git_pass(git_repository_fetchhead_foreach(repo, assert_master_for_merge, NULL)); diff --git a/tests/network/fetchlocal.c b/tests/network/fetchlocal.c index 13b3cf07c..a191b7b6b 100644 --- a/tests/network/fetchlocal.c +++ b/tests/network/fetchlocal.c @@ -34,19 +34,16 @@ void test_network_fetchlocal__complete(void)  	git_strarray refnames = {0};  	const char *url = cl_git_fixture_url("testrepo.git"); -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT; -	callbacks.transfer_progress = transfer_cb; -	callbacks.payload = &callcount; +	options.callbacks.transfer_progress = transfer_cb; +	options.callbacks.payload = &callcount;  	cl_set_cleanup(&cleanup_local_repo, "foo");  	cl_git_pass(git_repository_init(&repo, "foo", true));  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_connect(origin, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(origin, NULL)); -	cl_git_pass(git_remote_update_tips(origin, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(19, (int)refnames.count); @@ -66,17 +63,16 @@ void test_network_fetchlocal__prune(void)  	git_reference *ref;  	git_repository *remote_repo = cl_git_sandbox_init("testrepo.git");  	const char *url = cl_git_path_url(git_repository_path(remote_repo)); -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT; -	callbacks.transfer_progress = transfer_cb; -	callbacks.payload = &callcount; +	options.callbacks.transfer_progress = transfer_cb; +	options.callbacks.payload = &callcount;  	cl_set_cleanup(&cleanup_local_repo, "foo");  	cl_git_pass(git_repository_init(&repo, "foo", true));  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(19, (int)refnames.count); @@ -89,11 +85,8 @@ void test_network_fetchlocal__prune(void)  	git_reference_free(ref);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_connect(origin, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(origin, NULL)); -	cl_git_pass(git_remote_prune(origin)); -	cl_git_pass(git_remote_update_tips(origin, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL)); +	cl_git_pass(git_remote_prune(origin, &options.callbacks));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(18, (int)refnames.count); @@ -105,11 +98,8 @@ void test_network_fetchlocal__prune(void)  	git_reference_free(ref);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_connect(origin, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(origin, NULL)); -	cl_git_pass(git_remote_prune(origin)); -	cl_git_pass(git_remote_update_tips(origin, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL)); +	cl_git_pass(git_remote_prune(origin, &options.callbacks));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(17, (int)refnames.count); @@ -151,9 +141,9 @@ void test_network_fetchlocal__prune_overlapping(void)  	git_repository *remote_repo = cl_git_sandbox_init("testrepo.git");  	const char *url = cl_git_path_url(git_repository_path(remote_repo)); -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; -	callbacks.transfer_progress = transfer_cb; -	callbacks.payload = &callcount; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT; +	options.callbacks.transfer_progress = transfer_cb; +	options.callbacks.payload = &callcount;  	cl_git_pass(git_reference_lookup(&ref, remote_repo, "refs/heads/master"));  	git_oid_cpy(&target, git_reference_target(ref)); @@ -165,7 +155,6 @@ void test_network_fetchlocal__prune_overlapping(void)  	cl_git_pass(git_repository_init(&repo, "foo", true));  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	git_remote_set_callbacks(origin, &callbacks);  	cl_git_pass(git_repository_config(&config, repo));  	cl_git_pass(git_config_set_bool(config, "remote.origin.prune", true)); @@ -173,8 +162,7 @@ void test_network_fetchlocal__prune_overlapping(void)  	git_remote_free(origin);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	assert_ref_exists(repo, "refs/remotes/origin/master");  	assert_ref_exists(repo, "refs/remotes/origin/pr/42"); @@ -188,9 +176,8 @@ void test_network_fetchlocal__prune_overlapping(void)  	git_remote_free(origin);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); -	callbacks.update_tips = update_tips_fail_on_call; -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	options.callbacks.update_tips = update_tips_fail_on_call; +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	assert_ref_exists(repo, "refs/remotes/origin/master");  	assert_ref_exists(repo, "refs/remotes/origin/pr/42"); @@ -204,9 +191,8 @@ void test_network_fetchlocal__prune_overlapping(void)  	git_remote_free(origin);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); -	callbacks.update_tips = update_tips_fail_on_call; -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	options.callbacks.update_tips = update_tips_fail_on_call; +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	git_config_free(config);  	git_strarray_free(&refnames); @@ -224,17 +210,16 @@ void test_network_fetchlocal__fetchprune(void)  	git_config *config;  	git_repository *remote_repo = cl_git_sandbox_init("testrepo.git");  	const char *url = cl_git_path_url(git_repository_path(remote_repo)); -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT; -	callbacks.transfer_progress = transfer_cb; -	callbacks.payload = &callcount; +	options.callbacks.transfer_progress = transfer_cb; +	options.callbacks.payload = &callcount;  	cl_set_cleanup(&cleanup_local_repo, "foo");  	cl_git_pass(git_repository_init(&repo, "foo", true));  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(19, (int)refnames.count); @@ -247,9 +232,8 @@ void test_network_fetchlocal__fetchprune(void)  	git_reference_free(ref);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); -	cl_git_pass(git_remote_prune(origin)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL)); +	cl_git_pass(git_remote_prune(origin, &options.callbacks));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(18, (int)refnames.count); @@ -265,8 +249,7 @@ void test_network_fetchlocal__fetchprune(void)  	git_config_free(config);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN));  	cl_assert_equal_i(1, git_remote_prune_refs(origin)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(17, (int)refnames.count); @@ -289,17 +272,16 @@ void test_network_fetchlocal__prune_tag(void)  	git_repository *remote_repo = cl_git_sandbox_init("testrepo.git");  	const char *url = cl_git_path_url(git_repository_path(remote_repo)); -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT; -	callbacks.transfer_progress = transfer_cb; -	callbacks.payload = &callcount; +	options.callbacks.transfer_progress = transfer_cb; +	options.callbacks.payload = &callcount;  	cl_set_cleanup(&cleanup_local_repo, "foo");  	cl_git_pass(git_repository_init(&repo, "foo", true));  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	git_remote_free(origin);  	cl_git_pass(git_revparse_single(&obj, repo, "origin/master")); @@ -321,8 +303,7 @@ void test_network_fetchlocal__prune_tag(void)  	git_config_free(config);  	cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN));  	cl_assert_equal_i(1, git_remote_prune_refs(origin)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_fetch(origin, NULL, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	assert_ref_exists(repo, "refs/tags/some-tag");  	cl_git_fail_with(GIT_ENOTFOUND, git_reference_lookup(&ref, repo, "refs/remotes/origin/fake-remote")); @@ -346,10 +327,10 @@ void test_network_fetchlocal__partial(void)  	int callcount = 0;  	git_strarray refnames = {0};  	const char *url; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT; -	callbacks.transfer_progress = transfer_cb; -	callbacks.payload = &callcount; +	options.callbacks.transfer_progress = transfer_cb; +	options.callbacks.payload = &callcount;  	cl_set_cleanup(&cleanup_sandbox, NULL);  	cl_git_pass(git_reference_list(&refnames, repo)); @@ -357,10 +338,7 @@ void test_network_fetchlocal__partial(void)  	url = cl_git_fixture_url("testrepo.git");  	cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); -	git_remote_set_callbacks(origin, &callbacks); -	cl_git_pass(git_remote_connect(origin, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(origin, NULL)); -	cl_git_pass(git_remote_update_tips(origin, NULL)); +	cl_git_pass(git_remote_fetch(origin, NULL, &options, NULL));  	git_strarray_free(&refnames); @@ -418,16 +396,13 @@ void test_network_fetchlocal__multi_remotes(void)  	git_repository *repo = cl_git_sandbox_init("testrepo.git");  	git_remote *test, *test2;  	git_strarray refnames = {0}; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT;  	cl_set_cleanup(&cleanup_sandbox, NULL); -	callbacks.transfer_progress = transfer_cb; +	options.callbacks.transfer_progress = transfer_cb;  	cl_git_pass(git_remote_lookup(&test, repo, "test"));  	cl_git_pass(git_remote_set_url(test, cl_git_fixture_url("testrepo.git"))); -	git_remote_set_callbacks(test, &callbacks); -	cl_git_pass(git_remote_connect(test, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(test, NULL)); -	cl_git_pass(git_remote_update_tips(test, NULL)); +	cl_git_pass(git_remote_fetch(test, NULL, &options, NULL));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(32, (int)refnames.count); @@ -435,10 +410,7 @@ void test_network_fetchlocal__multi_remotes(void)  	cl_git_pass(git_remote_lookup(&test2, repo, "test_with_pushurl"));  	cl_git_pass(git_remote_set_url(test2, cl_git_fixture_url("testrepo.git"))); -	git_remote_set_callbacks(test2, &callbacks); -	cl_git_pass(git_remote_connect(test2, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(test2, NULL)); -	cl_git_pass(git_remote_update_tips(test2, NULL)); +	cl_git_pass(git_remote_fetch(test2, NULL, &options, NULL));  	cl_git_pass(git_reference_list(&refnames, repo));  	cl_assert_equal_i(44, (int)refnames.count); @@ -463,7 +435,7 @@ void test_network_fetchlocal__call_progress(void)  {  	git_repository *repo;  	git_remote *remote; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT;  	int callcount = 0;  	cl_git_pass(git_repository_init(&repo, "foo.git", true)); @@ -471,11 +443,10 @@ void test_network_fetchlocal__call_progress(void)  	cl_git_pass(git_remote_create_with_fetchspec(&remote, repo, "origin", cl_git_fixture_url("testrepo.git"), "+refs/heads/*:refs/heads/*")); -	callbacks.sideband_progress = sideband_cb; -	callbacks.payload = &callcount; -	cl_git_pass(git_remote_set_callbacks(remote, &callbacks)); +	options.callbacks.sideband_progress = sideband_cb; +	options.callbacks.payload = &callcount; -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, &options, NULL));  	cl_assert(callcount != 0);  	git_remote_free(remote); diff --git a/tests/network/remote/defaultbranch.c b/tests/network/remote/defaultbranch.c index c83d5c8b0..e83755ef6 100644 --- a/tests/network/remote/defaultbranch.c +++ b/tests/network/remote/defaultbranch.c @@ -26,7 +26,7 @@ static void assert_default_branch(const char *should)  {  	git_buf name = GIT_BUF_INIT; -	cl_git_pass(git_remote_connect(g_remote, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(g_remote, GIT_DIRECTION_FETCH, NULL));  	cl_git_pass(git_remote_default_branch(&name, g_remote));  	cl_assert_equal_s(should, name.ptr);  	git_buf_free(&name); @@ -57,7 +57,7 @@ void test_network_remote_defaultbranch__no_default_branch(void)  	git_buf buf = GIT_BUF_INIT;  	cl_git_pass(git_remote_create(&remote_b, g_repo_b, "self", git_repository_path(g_repo_b))); -	cl_git_pass(git_remote_connect(remote_b, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(remote_b, GIT_DIRECTION_FETCH, NULL));  	cl_git_pass(git_remote_ls(&heads, &len, remote_b));  	cl_assert_equal_i(0, len); @@ -80,7 +80,7 @@ void test_network_remote_defaultbranch__detached_sharing_nonbranch_id(void)  	cl_git_pass(git_reference_create(&ref, g_repo_a, "refs/foo/bar", &id, 1, NULL));  	git_reference_free(ref); -	cl_git_pass(git_remote_connect(g_remote, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(g_remote, GIT_DIRECTION_FETCH, NULL));  	cl_git_fail_with(GIT_ENOTFOUND, git_remote_default_branch(&buf, g_remote));  	cl_git_pass(git_clone(&cloned_repo, git_repository_path(g_repo_a), "./local-detached", NULL)); diff --git a/tests/network/remote/local.c b/tests/network/remote/local.c index ba54de6af..1e03371f0 100644 --- a/tests/network/remote/local.c +++ b/tests/network/remote/local.c @@ -40,7 +40,7 @@ static void connect_to_local_repository(const char *local_repository)  	git_buf_sets(&file_path_buf, cl_git_path_url(local_repository));  	cl_git_pass(git_remote_create_anonymous(&remote, repo, git_buf_cstr(&file_path_buf), NULL)); -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL));  }  void test_network_remote_local__connected(void) @@ -138,8 +138,7 @@ void test_network_remote_local__shorthand_fetch_refspec0(void)  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_download(remote, &array)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); +	cl_git_pass(git_remote_fetch(remote, &array, NULL, NULL));  	cl_git_pass(git_reference_lookup(&ref, repo, "refs/remotes/sloppy/master"));  	git_reference_free(ref); @@ -164,8 +163,7 @@ void test_network_remote_local__shorthand_fetch_refspec1(void)  	connect_to_local_repository(cl_fixture("testrepo.git"));  	git_remote_clear_refspecs(remote); -	cl_git_pass(git_remote_download(remote, &array)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); +	cl_git_pass(git_remote_fetch(remote, &array, NULL, NULL));  	cl_git_fail(git_reference_lookup(&ref, repo, "refs/remotes/master")); @@ -178,7 +176,7 @@ void test_network_remote_local__tagopt(void)  	cl_git_pass(git_remote_create(&remote, repo, "tagopt", cl_git_path_url(cl_fixture("testrepo.git"))));  	git_remote_set_autotag(remote, GIT_REMOTE_DOWNLOAD_TAGS_ALL); -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, NULL, NULL));  	cl_git_pass(git_reference_lookup(&ref, repo, "refs/remotes/tagopt/master"));  	git_reference_free(ref); @@ -186,7 +184,7 @@ void test_network_remote_local__tagopt(void)  	git_reference_free(ref);  	git_remote_set_autotag(remote, GIT_REMOTE_DOWNLOAD_TAGS_AUTO); -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, NULL, NULL));  	cl_git_pass(git_reference_lookup(&ref, repo, "refs/remotes/tagopt/master"));  	git_reference_free(ref);  } @@ -206,9 +204,7 @@ void test_network_remote_local__push_to_bare_remote(void)  	/* Get some commits */  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_download(remote, &array)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); -	git_remote_disconnect(remote); +	cl_git_pass(git_remote_fetch(remote, &array, NULL, NULL));  	/* Set up an empty bare repo to push into */  	{ @@ -219,7 +215,7 @@ void test_network_remote_local__push_to_bare_remote(void)  	/* Connect to the bare repo */  	cl_git_pass(git_remote_create_anonymous(&localremote, repo, "./localbare.git", NULL)); -	cl_git_pass(git_remote_connect(localremote, GIT_DIRECTION_PUSH)); +	cl_git_pass(git_remote_connect(localremote, GIT_DIRECTION_PUSH, NULL));  	/* Try to push */  	cl_git_pass(git_remote_upload(remote, &push_array, NULL)); @@ -244,8 +240,8 @@ void test_network_remote_local__push_to_bare_remote_with_file_url(void)  	/* Get some commits */  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_download(remote, &array)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); +	cl_git_pass(git_remote_download(remote, &array, NULL)); +	cl_git_pass(git_remote_update_tips(remote, NULL, NULL));  	git_remote_disconnect(remote);  	/* Set up an empty bare repo to push into */ @@ -260,7 +256,7 @@ void test_network_remote_local__push_to_bare_remote_with_file_url(void)  	/* Connect to the bare repo */  	cl_git_pass(git_remote_create_anonymous(&localremote, repo, url, NULL)); -	cl_git_pass(git_remote_connect(localremote, GIT_DIRECTION_PUSH)); +	cl_git_pass(git_remote_connect(localremote, GIT_DIRECTION_PUSH, NULL));  	/* Try to push */  	cl_git_pass(git_remote_upload(remote, &push_array, NULL)); @@ -285,8 +281,8 @@ void test_network_remote_local__push_to_non_bare_remote(void)  	/* Get some commits */  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_download(remote, &array)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); +	cl_git_pass(git_remote_download(remote, &array, NULL)); +	cl_git_pass(git_remote_update_tips(remote, NULL, NULL));  	git_remote_disconnect(remote);  	/* Set up an empty non-bare repo to push into */ @@ -298,7 +294,7 @@ void test_network_remote_local__push_to_non_bare_remote(void)  	/* Connect to the bare repo */  	cl_git_pass(git_remote_create_anonymous(&localremote, repo, "./localnonbare", NULL)); -	cl_git_pass(git_remote_connect(localremote, GIT_DIRECTION_PUSH)); +	cl_git_pass(git_remote_connect(localremote, GIT_DIRECTION_PUSH, NULL));  	/* Try to push */  	cl_git_fail_with(GIT_EBAREREPO, git_remote_upload(localremote, &push_array, NULL)); @@ -324,7 +320,7 @@ void test_network_remote_local__fetch(void)  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_fetch(remote, &array, "UPDAAAAAATE!!")); +	cl_git_pass(git_remote_fetch(remote, &array, NULL, "UPDAAAAAATE!!"));  	cl_git_pass(git_reference_lookup(&ref, repo, "refs/remotes/sloppy/master"));  	git_reference_free(ref); @@ -353,8 +349,8 @@ void test_network_remote_local__reflog(void)  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_download(remote, &array)); -	cl_git_pass(git_remote_update_tips(remote, "UPDAAAAAATE!!")); +	cl_git_pass(git_remote_download(remote, &array, NULL)); +	cl_git_pass(git_remote_update_tips(remote, NULL, "UPDAAAAAATE!!"));  	cl_git_pass(git_reflog_read(&log, repo, "refs/remotes/sloppy/master"));  	cl_assert_equal_i(1, git_reflog_entrycount(log)); @@ -381,7 +377,7 @@ void test_network_remote_local__fetch_default_reflog_message(void)  	connect_to_local_repository(cl_fixture("testrepo.git")); -	cl_git_pass(git_remote_fetch(remote, &array, NULL)); +	cl_git_pass(git_remote_fetch(remote, &array, NULL, NULL));  	cl_git_pass(git_reflog_read(&log, repo, "refs/remotes/sloppy/master"));  	cl_assert_equal_i(1, git_reflog_entrycount(log)); @@ -408,7 +404,7 @@ void test_network_remote_local__opportunistic_update(void)  	/* this remote has a passive refspec of "refs/heads/<star>:refs/remotes/origin/<star>" */  	cl_git_pass(git_remote_create(&remote, repo, "origin", cl_git_fixture_url("testrepo.git")));  	/* and we pass the active refspec "master" */ -	cl_git_pass(git_remote_fetch(remote, &array, NULL)); +	cl_git_pass(git_remote_fetch(remote, &array, NULL, NULL));  	/* and we expect that to update our copy of origin's master */  	cl_git_pass(git_reference_lookup(&ref, repo, "refs/remotes/origin/master")); @@ -430,11 +426,8 @@ void test_network_remote_local__update_tips_for_new_remote(void) {  	/* Push to bare repo */  	cl_git_pass(git_remote_create(&new_remote, src_repo, "bare", "./localbare.git")); -	cl_git_pass(git_remote_connect(new_remote, GIT_DIRECTION_PUSH)); -	cl_git_pass(git_remote_upload(new_remote, &push_array, NULL)); - -	/* Update tips and make sure remote branch has been created */ -	cl_git_pass(git_remote_update_tips(new_remote, NULL)); +	cl_git_pass(git_remote_push(new_remote, &push_array, NULL)); +	/* Make sure remote branch has been created */  	cl_git_pass(git_branch_lookup(&branch, src_repo, "bare/master", GIT_BRANCH_REMOTE));  	git_reference_free(branch); diff --git a/tests/network/remote/remotes.c b/tests/network/remote/remotes.c index 3e6e438cc..456fb39fe 100644 --- a/tests/network/remote/remotes.c +++ b/tests/network/remote/remotes.c @@ -86,7 +86,7 @@ void test_network_remote_remotes__error_when_no_push_available(void)  	cl_git_pass(git_remote_set_transport(r, git_transport_local, NULL)); -	cl_git_pass(git_remote_connect(r, GIT_DIRECTION_PUSH)); +	cl_git_pass(git_remote_connect(r, GIT_DIRECTION_PUSH, NULL));  	/* Make sure that push is really not available */  	r->transport->push = NULL; @@ -273,7 +273,7 @@ void test_network_remote_remotes__nonmatch_upstream_refspec(void)  	cl_git_pass(git_config_set_string(config, "branch.master.remote", "taggy"));  	cl_git_pass(git_config_set_string(config, "branch.master.merge", "refs/heads/foo")); -	cl_git_pass(git_remote_fetch(remote, &specs, NULL)); +	cl_git_pass(git_remote_fetch(remote, &specs, NULL, NULL));  	git_remote_free(remote);  } @@ -408,7 +408,7 @@ void test_network_remote_remotes__can_load_with_an_empty_url(void)  	cl_assert(remote->url == NULL);  	cl_assert(remote->pushurl == NULL); -	cl_git_fail(git_remote_connect(remote, GIT_DIRECTION_FETCH)); +	cl_git_fail(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL));  	cl_assert(giterr_last() != NULL);  	cl_assert(giterr_last()->klass == GITERR_INVALID); @@ -425,7 +425,7 @@ void test_network_remote_remotes__can_load_with_only_an_empty_pushurl(void)  	cl_assert(remote->url == NULL);  	cl_assert(remote->pushurl == NULL); -	cl_git_fail(git_remote_connect(remote, GIT_DIRECTION_FETCH)); +	cl_git_fail(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL));  	git_remote_free(remote);  } @@ -519,6 +519,6 @@ void test_network_remote_remotes__fetch_from_anonymous(void)  	cl_git_pass(git_remote_create_anonymous(&remote, _repo, cl_fixture("testrepo.git"),  						"refs/heads/*:refs/other/*")); -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, NULL, NULL));  	git_remote_free(remote);  } diff --git a/tests/online/clone.c b/tests/online/clone.c index 4fdeee1d2..35ddbe9af 100644 --- a/tests/online/clone.c +++ b/tests/online/clone.c @@ -20,7 +20,7 @@ static git_clone_options g_options;  void test_online_clone__initialize(void)  {  	git_checkout_options dummy_opts = GIT_CHECKOUT_OPTIONS_INIT; -	git_remote_callbacks dummy_callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options dummy_fetch = GIT_FETCH_OPTIONS_INIT;  	g_repo = NULL; @@ -28,7 +28,7 @@ void test_online_clone__initialize(void)  	g_options.version = GIT_CLONE_OPTIONS_VERSION;  	g_options.checkout_opts = dummy_opts;  	g_options.checkout_opts.checkout_strategy = GIT_CHECKOUT_SAFE; -	g_options.remote_callbacks = dummy_callbacks; +	g_options.fetch_opts = dummy_fetch;  }  void test_online_clone__cleanup(void) @@ -107,8 +107,8 @@ void test_online_clone__can_checkout_a_cloned_repo(void)  	g_options.checkout_opts.checkout_strategy = GIT_CHECKOUT_SAFE;  	g_options.checkout_opts.progress_cb = &checkout_progress;  	g_options.checkout_opts.progress_payload = &checkout_progress_cb_was_called; -	g_options.remote_callbacks.transfer_progress = &fetch_progress; -	g_options.remote_callbacks.payload = &fetch_progress_cb_was_called; +	g_options.fetch_opts.callbacks.transfer_progress = &fetch_progress; +	g_options.fetch_opts.callbacks.payload = &fetch_progress_cb_was_called;  	cl_git_pass(git_clone(&g_repo, LIVE_REPO_URL, "./foo", &g_options)); @@ -131,17 +131,12 @@ static int remote_mirror_cb(git_remote **out, git_repository *repo,  {  	int error;  	git_remote *remote; -	git_remote_callbacks *callbacks = (git_remote_callbacks *) payload; +	GIT_UNUSED(payload);  	if ((error = git_remote_create(&remote, repo, name, url)) < 0)  		return error; -	if ((error = git_remote_set_callbacks(remote, callbacks)) < 0) { -		git_remote_free(remote); -		return error; -	} -  	git_remote_clear_refspecs(remote);  	if ((error = git_remote_add_fetch(remote, "+refs/*:refs/*")) < 0) { @@ -157,16 +152,14 @@ void test_online_clone__clone_mirror(void)  {  	git_clone_options opts = GIT_CLONE_OPTIONS_INIT;  	git_reference *head; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT;  	bool fetch_progress_cb_was_called = false; -	callbacks.transfer_progress = &fetch_progress; -	callbacks.payload = &fetch_progress_cb_was_called; +	opts.fetch_opts.callbacks.transfer_progress = &fetch_progress; +	opts.fetch_opts.callbacks.payload = &fetch_progress_cb_was_called;  	opts.bare = true;  	opts.remote_cb = remote_mirror_cb; -	opts.remote_cb_payload = &callbacks;  	cl_git_pass(git_clone(&g_repo, LIVE_REPO_URL, "./foo.git", &opts)); @@ -195,8 +188,8 @@ void test_online_clone__custom_remote_callbacks(void)  {  	int callcount = 0; -	g_options.remote_callbacks.update_tips = update_tips; -	g_options.remote_callbacks.payload = &callcount; +	g_options.fetch_opts.callbacks.update_tips = update_tips; +	g_options.fetch_opts.callbacks.payload = &callcount;  	cl_git_pass(git_clone(&g_repo, LIVE_REPO_URL, "./foo", &g_options));  	cl_assert(callcount > 0); @@ -222,7 +215,7 @@ void test_online_clone__cred_callback_failure_return_code_is_tunnelled(void)  	if (!remote_url || !remote_user)  		clar__skip(); -	g_options.remote_callbacks.credentials = cred_failure_cb; +	g_options.fetch_opts.callbacks.credentials = cred_failure_cb;  	cl_git_fail_with(-172, git_clone(&g_repo, remote_url, "./foo", &g_options));  } @@ -254,8 +247,8 @@ void test_online_clone__cred_callback_called_again_on_auth_failure(void)  	if (!remote_url || !remote_user)  		clar__skip(); -	g_options.remote_callbacks.credentials = cred_count_calls_cb; -	g_options.remote_callbacks.payload = &counter; +	g_options.fetch_opts.callbacks.credentials = cred_count_calls_cb; +	g_options.fetch_opts.callbacks.payload = &counter;  	cl_git_fail_with(GIT_EUSER, git_clone(&g_repo, remote_url, "./foo", &g_options));  	cl_assert_equal_i(3, counter); @@ -292,10 +285,10 @@ void test_online_clone__credentials(void)  	if (!remote_url) return;  	if (cl_getenv("GITTEST_REMOTE_DEFAULT")) { -		g_options.remote_callbacks.credentials = cred_default; +		g_options.fetch_opts.callbacks.credentials = cred_default;  	} else { -		g_options.remote_callbacks.credentials = git_cred_userpass; -		g_options.remote_callbacks.payload = &user_pass; +		g_options.fetch_opts.callbacks.credentials = git_cred_userpass; +		g_options.fetch_opts.callbacks.payload = &user_pass;  	}  	cl_git_pass(git_clone(&g_repo, remote_url, "./foo", &g_options)); @@ -309,8 +302,8 @@ void test_online_clone__bitbucket_style(void)  		"libgit2", "libgit2"  	}; -	g_options.remote_callbacks.credentials = git_cred_userpass; -	g_options.remote_callbacks.payload = &user_pass; +	g_options.fetch_opts.callbacks.credentials = git_cred_userpass; +	g_options.fetch_opts.callbacks.payload = &user_pass;  	cl_git_pass(git_clone(&g_repo, BB_REPO_URL, "./foo", &g_options));  	git_repository_free(g_repo); g_repo = NULL; @@ -340,7 +333,7 @@ static int cancel_at_half(const git_transfer_progress *stats, void *payload)  void test_online_clone__can_cancel(void)  { -	g_options.remote_callbacks.transfer_progress = cancel_at_half; +	g_options.fetch_opts.callbacks.transfer_progress = cancel_at_half;  	cl_git_fail_with(  		git_clone(&g_repo, LIVE_REPO_URL, "./foo", &g_options), 4321); @@ -387,8 +380,8 @@ void test_online_clone__ssh_auth_methods(void)  #ifndef GIT_SSH  	clar__skip();  #endif -	g_options.remote_callbacks.credentials = check_ssh_auth_methods; -	g_options.remote_callbacks.payload = &with_user; +	g_options.fetch_opts.callbacks.credentials = check_ssh_auth_methods; +	g_options.fetch_opts.callbacks.payload = &with_user;  	with_user = 0;  	cl_git_fail_with(GIT_EUSER, @@ -407,7 +400,6 @@ static int custom_remote_ssh_with_paths(  	void *payload)  {  	int error; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT;  	if ((error = git_remote_create(out, repo, name, url)) < 0)  		return error; @@ -415,9 +407,6 @@ static int custom_remote_ssh_with_paths(  	if ((error = git_remote_set_transport(*out, git_transport_ssh_with_paths, payload)) < 0)  		return error; -	callbacks.credentials = cred_cb; -	git_remote_set_callbacks(*out, &callbacks); -  	return 0;  } @@ -468,7 +457,7 @@ void test_online_clone__ssh_cannot_change_username(void)  #ifndef GIT_SSH  	clar__skip();  #endif -	g_options.remote_callbacks.credentials = cred_foo_bar; +	g_options.fetch_opts.callbacks.credentials = cred_foo_bar;  	cl_git_fail(git_clone(&g_repo, "ssh://git@github.com/libgit2/TestGitRepository", "./foo", &g_options));  } @@ -511,7 +500,7 @@ int ssh_certificate_check(git_cert *cert, int valid, const char *host, void *pay  void test_online_clone__ssh_cert(void)  { -	g_options.remote_callbacks.certificate_check = ssh_certificate_check; +	g_options.fetch_opts.callbacks.certificate_check = ssh_certificate_check;  	if (!cl_getenv("GITTEST_REMOTE_SSH_FINGERPRINT"))  		cl_skip(); @@ -537,7 +526,7 @@ static int fail_certificate_check(git_cert *cert, int valid, const char *host, v  void test_online_clone__certificate_invalid(void)  { -	g_options.remote_callbacks.certificate_check = fail_certificate_check; +	g_options.fetch_opts.callbacks.certificate_check = fail_certificate_check;  	cl_git_fail_with(git_clone(&g_repo, "https://github.com/libgit2/TestGitRepository", "./foo", &g_options),  		GIT_ECERTIFICATE); @@ -561,14 +550,14 @@ static int succeed_certificate_check(git_cert *cert, int valid, const char *host  void test_online_clone__certificate_valid(void)  { -	g_options.remote_callbacks.certificate_check = succeed_certificate_check; +	g_options.fetch_opts.callbacks.certificate_check = succeed_certificate_check;  	cl_git_pass(git_clone(&g_repo, "https://github.com/libgit2/TestGitRepository", "./foo", &g_options));  }  void test_online_clone__start_with_http(void)  { -	g_options.remote_callbacks.certificate_check = succeed_certificate_check; +	g_options.fetch_opts.callbacks.certificate_check = succeed_certificate_check;  	cl_git_pass(git_clone(&g_repo, "http://github.com/libgit2/TestGitRepository", "./foo", &g_options));  } diff --git a/tests/online/fetch.c b/tests/online/fetch.c index 22f32ba1a..1a0f05039 100644 --- a/tests/online/fetch.c +++ b/tests/online/fetch.c @@ -35,21 +35,17 @@ static int progress(const git_transfer_progress *stats, void *payload)  static void do_fetch(const char *url, git_remote_autotag_option_t flag, int n)  {  	git_remote *remote; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT;  	size_t bytes_received = 0; -	callbacks.transfer_progress = progress; -	callbacks.update_tips = update_tips; -	callbacks.payload = &bytes_received; +	options.callbacks.transfer_progress = progress; +	options.callbacks.update_tips = update_tips; +	options.callbacks.payload = &bytes_received;  	counter = 0;  	cl_git_pass(git_remote_create(&remote, _repo, "test", url)); -	git_remote_set_callbacks(remote, &callbacks);  	git_remote_set_autotag(remote, flag); -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(remote, NULL)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); -	git_remote_disconnect(remote); +	cl_git_pass(git_remote_fetch(remote, NULL, &options, NULL));  	cl_assert_equal_i(counter, n);  	cl_assert(bytes_received > 0); @@ -85,12 +81,12 @@ void test_online_fetch__fetch_twice(void)  {  	git_remote *remote;  	cl_git_pass(git_remote_create(&remote, _repo, "test", "git://github.com/libgit2/TestGitRepository.git")); -    	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); -    	cl_git_pass(git_remote_download(remote, NULL)); +	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL)); +	cl_git_pass(git_remote_download(remote, NULL, NULL));      	git_remote_disconnect(remote); -    	git_remote_connect(remote, GIT_DIRECTION_FETCH); -	cl_git_pass(git_remote_download(remote, NULL)); +	git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL); +	cl_git_pass(git_remote_download(remote, NULL, NULL));  	git_remote_disconnect(remote);  	git_remote_free(remote); @@ -110,7 +106,7 @@ void test_online_fetch__doesnt_retrieve_a_pack_when_the_repository_is_up_to_date  	git_repository *_repository;  	bool invoked = false;  	git_remote *remote; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT;  	git_clone_options opts = GIT_CLONE_OPTIONS_INIT;  	opts.bare = true; @@ -121,18 +117,17 @@ void test_online_fetch__doesnt_retrieve_a_pack_when_the_repository_is_up_to_date  	cl_git_pass(git_repository_open(&_repository, "./fetch/lg2"));  	cl_git_pass(git_remote_lookup(&remote, _repository, "origin")); -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL));  	cl_assert_equal_i(false, invoked); -	callbacks.transfer_progress = &transferProgressCallback; -	callbacks.payload = &invoked; -	git_remote_set_callbacks(remote, &callbacks); -	cl_git_pass(git_remote_download(remote, NULL)); +	options.callbacks.transfer_progress = &transferProgressCallback; +	options.callbacks.payload = &invoked; +	cl_git_pass(git_remote_download(remote, NULL, &options));  	cl_assert_equal_i(false, invoked); -	cl_git_pass(git_remote_update_tips(remote, NULL)); +	cl_git_pass(git_remote_update_tips(remote, &options.callbacks, NULL));  	git_remote_disconnect(remote);  	git_remote_free(remote); @@ -152,17 +147,16 @@ void test_online_fetch__can_cancel(void)  {  	git_remote *remote;  	size_t bytes_received = 0; -	git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options options = GIT_FETCH_OPTIONS_INIT;  	cl_git_pass(git_remote_create(&remote, _repo, "test",  				"http://github.com/libgit2/TestGitRepository.git")); -	callbacks.transfer_progress = cancel_at_half; -	callbacks.payload = &bytes_received; -	git_remote_set_callbacks(remote, &callbacks); +	options.callbacks.transfer_progress = cancel_at_half; +	options.callbacks.payload = &bytes_received; -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); -	cl_git_fail_with(git_remote_download(remote, NULL), -4321); +	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL)); +	cl_git_fail_with(git_remote_download(remote, NULL, &options), -4321);  	git_remote_disconnect(remote);  	git_remote_free(remote);  } @@ -175,7 +169,7 @@ void test_online_fetch__ls_disconnected(void)  	cl_git_pass(git_remote_create(&remote, _repo, "test",  				"http://github.com/libgit2/TestGitRepository.git")); -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL));  	cl_git_pass(git_remote_ls(&refs, &refs_len_before, remote));  	git_remote_disconnect(remote);  	cl_git_pass(git_remote_ls(&refs, &refs_len_after, remote)); @@ -193,7 +187,7 @@ void test_online_fetch__remote_symrefs(void)  	cl_git_pass(git_remote_create(&remote, _repo, "test",  				"http://github.com/libgit2/TestGitRepository.git")); -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); +	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH, NULL));  	git_remote_disconnect(remote);  	cl_git_pass(git_remote_ls(&refs, &refs_len, remote)); @@ -208,8 +202,8 @@ void test_online_fetch__twice(void)  	git_remote *remote;  	cl_git_pass(git_remote_create(&remote, _repo, "test", "http://github.com/libgit2/TestGitRepository.git")); -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); -	cl_git_pass(git_remote_fetch(remote, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, NULL, NULL)); +	cl_git_pass(git_remote_fetch(remote, NULL, NULL, NULL));  	git_remote_free(remote);  } diff --git a/tests/online/fetchhead.c b/tests/online/fetchhead.c index 9a97abef3..b24b1b511 100644 --- a/tests/online/fetchhead.c +++ b/tests/online/fetchhead.c @@ -12,12 +12,12 @@ static git_clone_options g_options;  void test_online_fetchhead__initialize(void)  { -	git_remote_callbacks dummy_callbacks = GIT_REMOTE_CALLBACKS_INIT; +	git_fetch_options dummy_fetch = GIT_FETCH_OPTIONS_INIT;  	g_repo = NULL;  	memset(&g_options, 0, sizeof(git_clone_options));  	g_options.version = GIT_CLONE_OPTIONS_VERSION; -	g_options.remote_callbacks = dummy_callbacks; +	g_options.fetch_opts = dummy_fetch;  }  void test_online_fetchhead__cleanup(void) @@ -51,10 +51,7 @@ static void fetchhead_test_fetch(const char *fetchspec, const char *expected_fet  		active_refs = &array;  	} -	cl_git_pass(git_remote_connect(remote, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(remote, active_refs)); -	cl_git_pass(git_remote_update_tips(remote, NULL)); -	git_remote_disconnect(remote); +	cl_git_pass(git_remote_fetch(remote, active_refs, NULL, NULL));  	git_remote_free(remote);  	cl_git_pass(git_futils_readbuffer(&fetchhead_buf, "./foo/.git/FETCH_HEAD")); diff --git a/tests/online/push.c b/tests/online/push.c index 9b98bc77a..b35632755 100644 --- a/tests/online/push.c +++ b/tests/online/push.c @@ -369,9 +369,8 @@ void test_online_push__initialize(void)  	cl_git_pass(git_remote_create(&_remote, _repo, "test", _remote_url));  	record_callbacks_data_clear(&_record_cbs_data); -	git_remote_set_callbacks(_remote, &_record_cbs); -	cl_git_pass(git_remote_connect(_remote, GIT_DIRECTION_PUSH)); +	cl_git_pass(git_remote_connect(_remote, GIT_DIRECTION_PUSH, NULL));  	/* Clean up previously pushed branches.  Fails if receive.denyDeletes is  	 * set on the remote.  Also, on Git 1.7.0 and newer, you must run @@ -394,10 +393,7 @@ void test_online_push__initialize(void)  	git_vector_free(&delete_specs);  	/* Now that we've deleted everything, fetch from the remote */ -	cl_git_pass(git_remote_connect(_remote, GIT_DIRECTION_FETCH)); -	cl_git_pass(git_remote_download(_remote, NULL)); -	cl_git_pass(git_remote_update_tips(_remote, NULL)); -	git_remote_disconnect(_remote); +	cl_git_pass(git_remote_fetch(_remote, NULL, NULL, NULL));  }  void test_online_push__cleanup(void) @@ -459,20 +455,18 @@ static void do_push(  	size_t i;  	int error;  	git_strarray specs = {0}; -	git_remote_callbacks callbacks;  	record_callbacks_data *data;  	if (_remote) {  		/* Auto-detect the number of threads to use */  		opts.pb_parallelism = 0; -		memcpy(&callbacks, git_remote_get_callbacks(_remote), sizeof(callbacks)); -		data = callbacks.payload; +		memcpy(&opts.callbacks, &_record_cbs, sizeof(git_remote_callbacks)); +		data = opts.callbacks.payload; -		callbacks.pack_progress = push_pack_progress_cb; -		callbacks.push_transfer_progress = push_transfer_progress_cb; -		callbacks.push_update_reference = record_push_status_cb; -		cl_git_pass(git_remote_set_callbacks(_remote, &callbacks)); +		opts.callbacks.pack_progress = push_pack_progress_cb; +		opts.callbacks.push_transfer_progress = push_transfer_progress_cb; +		opts.callbacks.push_update_reference = record_push_status_cb;  		if (refspecs_len) {  			specs.count = refspecs_len; diff --git a/tests/submodule/update.c b/tests/submodule/update.c index 533e64efc..e7f1b76b8 100644 --- a/tests/submodule/update.c +++ b/tests/submodule/update.c @@ -96,8 +96,8 @@ void test_submodule_update__update_submodule(void)  	update_options.checkout_opts.progress_cb = checkout_progress_cb;  	update_options.checkout_opts.progress_payload = &update_payload; -	update_options.remote_callbacks.update_tips = update_tips; -	update_options.remote_callbacks.payload = &update_payload; +	update_options.fetch_opts.callbacks.update_tips = update_tips; +	update_options.fetch_opts.callbacks.payload = &update_payload;  	/* get the submodule */  	cl_git_pass(git_submodule_lookup(&sm, g_repo, "testrepo")); | 
