mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-02 14:37:30 +00:00
570 lines
17 KiB
C
570 lines
17 KiB
C
#include "clar_libgit2.h"
|
|
#include "buffer.h"
|
|
#include "refspec.h"
|
|
#include "remote.h"
|
|
|
|
static git_remote *_remote;
|
|
static git_repository *_repo;
|
|
static const git_refspec *_refspec;
|
|
|
|
void test_network_remote_remotes__initialize(void)
|
|
{
|
|
_repo = cl_git_sandbox_init("testrepo.git");
|
|
|
|
cl_git_pass(git_remote_lookup(&_remote, _repo, "test"));
|
|
|
|
_refspec = git_remote_get_refspec(_remote, 0);
|
|
cl_assert(_refspec != NULL);
|
|
}
|
|
|
|
void test_network_remote_remotes__cleanup(void)
|
|
{
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_git_sandbox_cleanup();
|
|
}
|
|
|
|
void test_network_remote_remotes__parsing(void)
|
|
{
|
|
git_remote *_remote2 = NULL;
|
|
|
|
cl_assert_equal_s(git_remote_name(_remote), "test");
|
|
cl_assert_equal_s(git_remote_url(_remote), "git://github.com/libgit2/libgit2");
|
|
cl_assert(git_remote_pushurl(_remote) == NULL);
|
|
|
|
cl_assert_equal_s(git_remote__urlfordirection(_remote, GIT_DIRECTION_FETCH),
|
|
"git://github.com/libgit2/libgit2");
|
|
cl_assert_equal_s(git_remote__urlfordirection(_remote, GIT_DIRECTION_PUSH),
|
|
"git://github.com/libgit2/libgit2");
|
|
|
|
cl_git_pass(git_remote_lookup(&_remote2, _repo, "test_with_pushurl"));
|
|
cl_assert_equal_s(git_remote_name(_remote2), "test_with_pushurl");
|
|
cl_assert_equal_s(git_remote_url(_remote2), "git://github.com/libgit2/fetchlibgit2");
|
|
cl_assert_equal_s(git_remote_pushurl(_remote2), "git://github.com/libgit2/pushlibgit2");
|
|
|
|
cl_assert_equal_s(git_remote__urlfordirection(_remote2, GIT_DIRECTION_FETCH),
|
|
"git://github.com/libgit2/fetchlibgit2");
|
|
cl_assert_equal_s(git_remote__urlfordirection(_remote2, GIT_DIRECTION_PUSH),
|
|
"git://github.com/libgit2/pushlibgit2");
|
|
|
|
git_remote_free(_remote2);
|
|
}
|
|
|
|
void test_network_remote_remotes__pushurl(void)
|
|
{
|
|
cl_git_pass(git_remote_set_pushurl(_remote, "git://github.com/libgit2/notlibgit2"));
|
|
cl_assert_equal_s(git_remote_pushurl(_remote), "git://github.com/libgit2/notlibgit2");
|
|
|
|
cl_git_pass(git_remote_set_pushurl(_remote, NULL));
|
|
cl_assert(git_remote_pushurl(_remote) == NULL);
|
|
}
|
|
|
|
void test_network_remote_remotes__error_when_not_found(void)
|
|
{
|
|
git_remote *r;
|
|
cl_git_fail_with(git_remote_lookup(&r, _repo, "does-not-exist"), GIT_ENOTFOUND);
|
|
|
|
cl_assert(giterr_last() != NULL);
|
|
cl_assert(giterr_last()->klass == GITERR_CONFIG);
|
|
}
|
|
|
|
void test_network_remote_remotes__error_when_no_push_available(void)
|
|
{
|
|
git_remote *r;
|
|
git_push *p;
|
|
|
|
cl_git_pass(git_remote_create_anonymous(&r, _repo, cl_fixture("testrepo.git"), NULL));
|
|
|
|
cl_git_pass(git_remote_set_transport(r, git_transport_local, NULL));
|
|
|
|
cl_git_pass(git_remote_connect(r, GIT_DIRECTION_PUSH));
|
|
|
|
/* Make sure that push is really not available */
|
|
r->transport->push = NULL;
|
|
|
|
cl_git_pass(git_push_new(&p, r));
|
|
cl_git_pass(git_push_add_refspec(p, "refs/heads/master"));
|
|
cl_git_fail_with(git_push_finish(p), GIT_ERROR);
|
|
|
|
git_push_free(p);
|
|
git_remote_free(r);
|
|
}
|
|
|
|
void test_network_remote_remotes__refspec_parsing(void)
|
|
{
|
|
cl_assert_equal_s(git_refspec_src(_refspec), "refs/heads/*");
|
|
cl_assert_equal_s(git_refspec_dst(_refspec), "refs/remotes/test/*");
|
|
}
|
|
|
|
void test_network_remote_remotes__add_fetchspec(void)
|
|
{
|
|
size_t size;
|
|
|
|
size = git_remote_refspec_count(_remote);
|
|
|
|
cl_git_pass(git_remote_add_fetch(_remote, "refs/*:refs/*"));
|
|
|
|
size++;
|
|
cl_assert_equal_i((int)size, (int)git_remote_refspec_count(_remote));
|
|
|
|
_refspec = git_remote_get_refspec(_remote, size - 1);
|
|
cl_assert_equal_s(git_refspec_src(_refspec), "refs/*");
|
|
cl_assert_equal_s(git_refspec_dst(_refspec), "refs/*");
|
|
cl_assert_equal_s(git_refspec_string(_refspec), "refs/*:refs/*");
|
|
cl_assert_equal_b(_refspec->push, false);
|
|
}
|
|
|
|
void test_network_remote_remotes__dup(void)
|
|
{
|
|
git_strarray array;
|
|
git_remote *dup;
|
|
|
|
cl_git_pass(git_remote_dup(&dup, _remote));
|
|
|
|
cl_assert_equal_s(git_remote_name(dup), git_remote_name(_remote));
|
|
cl_assert_equal_s(git_remote_url(dup), git_remote_url(_remote));
|
|
cl_assert_equal_s(git_remote_pushurl(dup), git_remote_pushurl(_remote));
|
|
|
|
cl_git_pass(git_remote_get_fetch_refspecs(&array, _remote));
|
|
cl_assert_equal_i(1, (int)array.count);
|
|
cl_assert_equal_s("+refs/heads/*:refs/remotes/test/*", array.strings[0]);
|
|
git_strarray_free(&array);
|
|
|
|
cl_git_pass(git_remote_get_push_refspecs(&array, _remote));
|
|
cl_assert_equal_i(0, (int)array.count);
|
|
git_strarray_free(&array);
|
|
|
|
git_remote_free(dup);
|
|
}
|
|
|
|
void test_network_remote_remotes__add_pushspec(void)
|
|
{
|
|
size_t size;
|
|
|
|
size = git_remote_refspec_count(_remote);
|
|
|
|
cl_git_pass(git_remote_add_push(_remote, "refs/*:refs/*"));
|
|
size++;
|
|
cl_assert_equal_i((int)size, (int)git_remote_refspec_count(_remote));
|
|
|
|
_refspec = git_remote_get_refspec(_remote, size - 1);
|
|
cl_assert_equal_s(git_refspec_src(_refspec), "refs/*");
|
|
cl_assert_equal_s(git_refspec_dst(_refspec), "refs/*");
|
|
cl_assert_equal_s(git_refspec_string(_refspec), "refs/*:refs/*");
|
|
|
|
cl_assert_equal_b(_refspec->push, true);
|
|
}
|
|
|
|
void test_network_remote_remotes__save(void)
|
|
{
|
|
git_strarray array;
|
|
const char *fetch_refspec1 = "refs/heads/ns1/*:refs/remotes/upstream/ns1/*";
|
|
const char *fetch_refspec2 = "refs/heads/ns2/*:refs/remotes/upstream/ns2/*";
|
|
const char *push_refspec1 = "refs/heads/ns1/*:refs/heads/ns1/*";
|
|
const char *push_refspec2 = "refs/heads/ns2/*:refs/heads/ns2/*";
|
|
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
/* Set up the remote and save it to config */
|
|
cl_git_pass(git_remote_create(&_remote, _repo, "upstream", "git://github.com/libgit2/libgit2"));
|
|
git_remote_clear_refspecs(_remote);
|
|
|
|
cl_git_pass(git_remote_add_fetch(_remote, fetch_refspec1));
|
|
cl_git_pass(git_remote_add_fetch(_remote, fetch_refspec2));
|
|
cl_git_pass(git_remote_add_push(_remote, push_refspec1));
|
|
cl_git_pass(git_remote_add_push(_remote, push_refspec2));
|
|
cl_git_pass(git_remote_set_pushurl(_remote, "git://github.com/libgit2/libgit2_push"));
|
|
cl_git_pass(git_remote_save(_remote));
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
/* Load it from config and make sure everything matches */
|
|
cl_git_pass(git_remote_lookup(&_remote, _repo, "upstream"));
|
|
|
|
cl_git_pass(git_remote_get_fetch_refspecs(&array, _remote));
|
|
cl_assert_equal_i(2, (int)array.count);
|
|
cl_assert_equal_s(fetch_refspec1, array.strings[0]);
|
|
cl_assert_equal_s(fetch_refspec2, array.strings[1]);
|
|
git_strarray_free(&array);
|
|
|
|
cl_git_pass(git_remote_get_push_refspecs(&array, _remote));
|
|
cl_assert_equal_i(2, (int)array.count);
|
|
cl_assert_equal_s(push_refspec1, array.strings[0]);
|
|
cl_assert_equal_s(push_refspec2, array.strings[1]);
|
|
git_strarray_free(&array);
|
|
|
|
cl_assert_equal_s(git_remote_url(_remote), "git://github.com/libgit2/libgit2");
|
|
cl_assert_equal_s(git_remote_pushurl(_remote), "git://github.com/libgit2/libgit2_push");
|
|
|
|
/* remove the pushurl again and see if we can save that too */
|
|
cl_git_pass(git_remote_set_pushurl(_remote, NULL));
|
|
cl_git_pass(git_remote_save(_remote));
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_git_pass(git_remote_lookup(&_remote, _repo, "upstream"));
|
|
cl_assert(git_remote_pushurl(_remote) == NULL);
|
|
}
|
|
|
|
void test_network_remote_remotes__fnmatch(void)
|
|
{
|
|
cl_assert(git_refspec_src_matches(_refspec, "refs/heads/master"));
|
|
cl_assert(git_refspec_src_matches(_refspec, "refs/heads/multi/level/branch"));
|
|
}
|
|
|
|
void test_network_remote_remotes__transform(void)
|
|
{
|
|
git_buf ref = GIT_BUF_INIT;
|
|
|
|
cl_git_pass(git_refspec_transform(&ref, _refspec, "refs/heads/master"));
|
|
cl_assert_equal_s(ref.ptr, "refs/remotes/test/master");
|
|
git_buf_free(&ref);
|
|
}
|
|
|
|
void test_network_remote_remotes__transform_destination_to_source(void)
|
|
{
|
|
git_buf ref = GIT_BUF_INIT;
|
|
|
|
cl_git_pass(git_refspec_rtransform(&ref, _refspec, "refs/remotes/test/master"));
|
|
cl_assert_equal_s(ref.ptr, "refs/heads/master");
|
|
git_buf_free(&ref);
|
|
}
|
|
|
|
void test_network_remote_remotes__missing_refspecs(void)
|
|
{
|
|
git_config *cfg;
|
|
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_git_pass(git_repository_config(&cfg, _repo));
|
|
cl_git_pass(git_config_set_string(cfg, "remote.specless.url", "http://example.com"));
|
|
cl_git_pass(git_remote_lookup(&_remote, _repo, "specless"));
|
|
|
|
git_config_free(cfg);
|
|
}
|
|
|
|
void test_network_remote_remotes__nonmatch_upstream_refspec(void)
|
|
{
|
|
git_config *config;
|
|
git_remote *remote;
|
|
char *specstr[] = {
|
|
"refs/tags/*:refs/tags/*",
|
|
};
|
|
git_strarray specs = {
|
|
specstr,
|
|
1,
|
|
};
|
|
|
|
cl_git_pass(git_remote_create(&remote, _repo, "taggy", git_repository_path(_repo)));
|
|
|
|
/*
|
|
* Set the current branch's upstream remote to a dummy ref so we call into the code
|
|
* which tries to check for the current branch's upstream in the refspecs
|
|
*/
|
|
cl_git_pass(git_repository_config(&config, _repo));
|
|
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, NULL));
|
|
|
|
git_remote_free(remote);
|
|
}
|
|
|
|
void test_network_remote_remotes__list(void)
|
|
{
|
|
git_strarray list;
|
|
git_config *cfg;
|
|
|
|
cl_git_pass(git_remote_list(&list, _repo));
|
|
cl_assert(list.count == 5);
|
|
git_strarray_free(&list);
|
|
|
|
cl_git_pass(git_repository_config(&cfg, _repo));
|
|
|
|
/* Create a new remote */
|
|
cl_git_pass(git_config_set_string(cfg, "remote.specless.url", "http://example.com"));
|
|
|
|
/* Update a remote (previously without any url/pushurl entry) */
|
|
cl_git_pass(git_config_set_string(cfg, "remote.no-remote-url.pushurl", "http://example.com"));
|
|
|
|
cl_git_pass(git_remote_list(&list, _repo));
|
|
cl_assert(list.count == 7);
|
|
git_strarray_free(&list);
|
|
|
|
git_config_free(cfg);
|
|
}
|
|
|
|
void test_network_remote_remotes__loading_a_missing_remote_returns_ENOTFOUND(void)
|
|
{
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_assert_equal_i(GIT_ENOTFOUND, git_remote_lookup(&_remote, _repo, "just-left-few-minutes-ago"));
|
|
}
|
|
|
|
void test_network_remote_remotes__loading_with_an_invalid_name_returns_EINVALIDSPEC(void)
|
|
{
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_assert_equal_i(GIT_EINVALIDSPEC, git_remote_lookup(&_remote, _repo, "Inv@{id"));
|
|
}
|
|
|
|
/*
|
|
* $ git remote add addtest http://github.com/libgit2/libgit2
|
|
*
|
|
* $ cat .git/config
|
|
* [...]
|
|
* [remote "addtest"]
|
|
* url = http://github.com/libgit2/libgit2
|
|
* fetch = +refs/heads/\*:refs/remotes/addtest/\*
|
|
*/
|
|
void test_network_remote_remotes__add(void)
|
|
{
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_git_pass(git_remote_create(&_remote, _repo, "addtest", "http://github.com/libgit2/libgit2"));
|
|
cl_assert_equal_i(GIT_REMOTE_DOWNLOAD_TAGS_AUTO, git_remote_autotag(_remote));
|
|
|
|
git_remote_free(_remote);
|
|
_remote = NULL;
|
|
|
|
cl_git_pass(git_remote_lookup(&_remote, _repo, "addtest"));
|
|
cl_assert_equal_i(GIT_REMOTE_DOWNLOAD_TAGS_AUTO, git_remote_autotag(_remote));
|
|
|
|
_refspec = git_vector_get(&_remote->refspecs, 0);
|
|
cl_assert_equal_s("refs/heads/*", git_refspec_src(_refspec));
|
|
cl_assert(git_refspec_force(_refspec) == 1);
|
|
cl_assert_equal_s("refs/remotes/addtest/*", git_refspec_dst(_refspec));
|
|
cl_assert_equal_s(git_remote_url(_remote), "http://github.com/libgit2/libgit2");
|
|
}
|
|
|
|
void test_network_remote_remotes__cannot_add_a_nameless_remote(void)
|
|
{
|
|
git_remote *remote;
|
|
|
|
cl_assert_equal_i(
|
|
GIT_EINVALIDSPEC,
|
|
git_remote_create(&remote, _repo, NULL, "git://github.com/libgit2/libgit2"));
|
|
}
|
|
|
|
void test_network_remote_remotes__cannot_save_an_inmemory_remote(void)
|
|
{
|
|
git_remote *remote;
|
|
|
|
cl_git_pass(git_remote_create_anonymous(&remote, _repo, "git://github.com/libgit2/libgit2", NULL));
|
|
|
|
cl_assert_equal_p(NULL, git_remote_name(remote));
|
|
|
|
cl_git_fail(git_remote_save(remote));
|
|
git_remote_free(remote);
|
|
}
|
|
|
|
void test_network_remote_remotes__cannot_add_a_remote_with_an_invalid_name(void)
|
|
{
|
|
git_remote *remote = NULL;
|
|
|
|
cl_assert_equal_i(
|
|
GIT_EINVALIDSPEC,
|
|
git_remote_create(&remote, _repo, "Inv@{id", "git://github.com/libgit2/libgit2"));
|
|
cl_assert_equal_p(remote, NULL);
|
|
|
|
cl_assert_equal_i(
|
|
GIT_EINVALIDSPEC,
|
|
git_remote_create(&remote, _repo, "", "git://github.com/libgit2/libgit2"));
|
|
cl_assert_equal_p(remote, NULL);
|
|
}
|
|
|
|
void test_network_remote_remotes__tagopt(void)
|
|
{
|
|
const char *opt;
|
|
git_config *cfg;
|
|
|
|
cl_git_pass(git_repository_config(&cfg, _repo));
|
|
|
|
git_remote_set_autotag(_remote, GIT_REMOTE_DOWNLOAD_TAGS_ALL);
|
|
cl_git_pass(git_remote_save(_remote));
|
|
cl_git_pass(git_config_get_string(&opt, cfg, "remote.test.tagopt"));
|
|
cl_assert_equal_s("--tags", opt);
|
|
|
|
git_remote_set_autotag(_remote, GIT_REMOTE_DOWNLOAD_TAGS_NONE);
|
|
cl_git_pass(git_remote_save(_remote));
|
|
cl_git_pass(git_config_get_string(&opt, cfg, "remote.test.tagopt"));
|
|
cl_assert_equal_s("--no-tags", opt);
|
|
|
|
git_remote_set_autotag(_remote, GIT_REMOTE_DOWNLOAD_TAGS_AUTO);
|
|
cl_git_pass(git_remote_save(_remote));
|
|
cl_assert(git_config_get_string(&opt, cfg, "remote.test.tagopt") == GIT_ENOTFOUND);
|
|
|
|
git_config_free(cfg);
|
|
}
|
|
|
|
void test_network_remote_remotes__can_load_with_an_empty_url(void)
|
|
{
|
|
git_remote *remote = NULL;
|
|
|
|
cl_git_pass(git_remote_lookup(&remote, _repo, "empty-remote-url"));
|
|
|
|
cl_assert(remote->url == NULL);
|
|
cl_assert(remote->pushurl == NULL);
|
|
|
|
cl_git_fail(git_remote_connect(remote, GIT_DIRECTION_FETCH));
|
|
|
|
cl_assert(giterr_last() != NULL);
|
|
cl_assert(giterr_last()->klass == GITERR_INVALID);
|
|
|
|
git_remote_free(remote);
|
|
}
|
|
|
|
void test_network_remote_remotes__can_load_with_only_an_empty_pushurl(void)
|
|
{
|
|
git_remote *remote = NULL;
|
|
|
|
cl_git_pass(git_remote_lookup(&remote, _repo, "empty-remote-pushurl"));
|
|
|
|
cl_assert(remote->url == NULL);
|
|
cl_assert(remote->pushurl == NULL);
|
|
|
|
cl_git_fail(git_remote_connect(remote, GIT_DIRECTION_FETCH));
|
|
|
|
git_remote_free(remote);
|
|
}
|
|
|
|
void test_network_remote_remotes__returns_ENOTFOUND_when_neither_url_nor_pushurl(void)
|
|
{
|
|
git_remote *remote = NULL;
|
|
|
|
cl_git_fail_with(
|
|
git_remote_lookup(&remote, _repo, "no-remote-url"), GIT_ENOTFOUND);
|
|
}
|
|
|
|
void assert_cannot_create_remote(const char *name, int expected_error)
|
|
{
|
|
git_remote *remote = NULL;
|
|
|
|
cl_git_fail_with(
|
|
git_remote_create(&remote, _repo, name, "git://github.com/libgit2/libgit2"),
|
|
expected_error);
|
|
|
|
cl_assert_equal_p(remote, NULL);
|
|
}
|
|
|
|
void test_network_remote_remotes__cannot_create_a_remote_which_name_conflicts_with_an_existing_remote(void)
|
|
{
|
|
assert_cannot_create_remote("test", GIT_EEXISTS);
|
|
}
|
|
|
|
void test_network_remote_remotes__cannot_create_a_remote_which_name_is_invalid(void)
|
|
{
|
|
assert_cannot_create_remote("/", GIT_EINVALIDSPEC);
|
|
assert_cannot_create_remote("//", GIT_EINVALIDSPEC);
|
|
assert_cannot_create_remote(".lock", GIT_EINVALIDSPEC);
|
|
assert_cannot_create_remote("a.lock", GIT_EINVALIDSPEC);
|
|
}
|
|
|
|
void test_network_remote_remote__git_remote_create_with_fetchspec(void)
|
|
{
|
|
git_remote *remote;
|
|
git_strarray array;
|
|
|
|
cl_git_pass(git_remote_create_with_fetchspec(&remote, _repo, "test-new", "git://github.com/libgit2/libgit2", "+refs/*:refs/*"));
|
|
git_remote_get_fetch_refspecs(&array, remote);
|
|
cl_assert_equal_s("+refs/*:refs/*", array.strings[0]);
|
|
git_remote_free(remote);
|
|
}
|
|
|
|
static const char *fetch_refspecs[] = {
|
|
"+refs/heads/*:refs/remotes/origin/*",
|
|
"refs/tags/*:refs/tags/*",
|
|
"+refs/pull/*:refs/pull/*",
|
|
};
|
|
|
|
static const char *push_refspecs[] = {
|
|
"refs/heads/*:refs/heads/*",
|
|
"refs/tags/*:refs/tags/*",
|
|
"refs/notes/*:refs/notes/*",
|
|
};
|
|
|
|
void test_network_remote_remotes__query_refspecs(void)
|
|
{
|
|
git_remote *remote;
|
|
git_strarray array;
|
|
int i;
|
|
|
|
cl_git_pass(git_remote_create_anonymous(&remote, _repo, "git://github.com/libgit2/libgit2", NULL));
|
|
|
|
for (i = 0; i < 3; i++) {
|
|
cl_git_pass(git_remote_add_fetch(remote, fetch_refspecs[i]));
|
|
cl_git_pass(git_remote_add_push(remote, push_refspecs[i]));
|
|
}
|
|
|
|
cl_git_pass(git_remote_get_fetch_refspecs(&array, remote));
|
|
for (i = 0; i < 3; i++) {
|
|
cl_assert_equal_s(fetch_refspecs[i], array.strings[i]);
|
|
}
|
|
git_strarray_free(&array);
|
|
|
|
cl_git_pass(git_remote_get_push_refspecs(&array, remote));
|
|
for (i = 0; i < 3; i++) {
|
|
cl_assert_equal_s(push_refspecs[i], array.strings[i]);
|
|
}
|
|
git_strarray_free(&array);
|
|
|
|
git_remote_free(remote);
|
|
}
|
|
|
|
static int remote_single_branch(git_remote **out, git_repository *repo, const char *name, const char *url, void *payload)
|
|
{
|
|
char *fetch_refspecs[] = {
|
|
"refs/heads/first-merge:refs/remotes/origin/first-merge",
|
|
};
|
|
git_strarray fetch_refspecs_strarray = {
|
|
fetch_refspecs,
|
|
1,
|
|
};
|
|
|
|
GIT_UNUSED(payload);
|
|
|
|
cl_git_pass(git_remote_create(out, repo, name, url));
|
|
cl_git_pass(git_remote_set_fetch_refspecs(*out, &fetch_refspecs_strarray));
|
|
|
|
return 0;
|
|
}
|
|
|
|
void test_network_remote_remotes__single_branch(void)
|
|
{
|
|
git_clone_options opts = GIT_CLONE_OPTIONS_INIT;
|
|
git_repository *repo;
|
|
git_strarray refs;
|
|
size_t i, count = 0;
|
|
|
|
opts.remote_cb = remote_single_branch;
|
|
opts.checkout_branch = "first-merge";
|
|
|
|
cl_git_pass(git_clone(&repo, "git://github.com/libgit2/TestGitRepository", "./single-branch", &opts));
|
|
cl_git_pass(git_reference_list(&refs, repo));
|
|
|
|
for (i = 0; i < refs.count; i++) {
|
|
if (!git__prefixcmp(refs.strings[i], "refs/heads/"))
|
|
count++;
|
|
}
|
|
cl_assert_equal_i(1, count);
|
|
|
|
git_strarray_free(&refs);
|
|
git_repository_free(repo);
|
|
}
|
|
|
|
void test_network_remote_remotes__restricted_refspecs(void)
|
|
{
|
|
git_clone_options opts = GIT_CLONE_OPTIONS_INIT;
|
|
git_repository *repo;
|
|
|
|
opts.remote_cb = remote_single_branch;
|
|
|
|
cl_git_fail_with(GIT_EINVALIDSPEC, git_clone(&repo, "git://github.com/libgit2/TestGitRepository", "./restrict-refspec", &opts));
|
|
}
|