|
Packit |
ae9e2a |
#include "clar_libgit2.h"
|
|
Packit |
ae9e2a |
#include "branch.h"
|
|
Packit |
ae9e2a |
#include "remote.h"
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
static git_repository *g_repo;
|
|
Packit |
ae9e2a |
static const char *remote_tracking_branch_name = "refs/remotes/test/master";
|
|
Packit |
ae9e2a |
static const char *expected_remote_name = "test";
|
|
Packit |
ae9e2a |
static int expected_remote_name_length;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_branches_remote__initialize(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
g_repo = cl_git_sandbox_init("testrepo");
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
expected_remote_name_length = (int)strlen(expected_remote_name) + 1;
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_branches_remote__cleanup(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
cl_git_sandbox_cleanup();
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_branches_remote__can_get_remote_for_branch(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
git_buf remotename = {0};
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_git_pass(git_branch_remote_name(&remotename, g_repo, remote_tracking_branch_name));
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
cl_assert_equal_s("test", remotename.ptr);
|
|
Packit |
ae9e2a |
git_buf_free(&remotename);
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_branches_remote__no_matching_remote_returns_error(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
const char *unknown = "refs/remotes/nonexistent/master";
|
|
Packit |
ae9e2a |
git_buf buf;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
giterr_clear();
|
|
Packit |
ae9e2a |
memset(&buf, 0, sizeof(git_buf));
|
|
Packit |
ae9e2a |
cl_git_fail_with(git_branch_remote_name(&buf, g_repo, unknown), GIT_ENOTFOUND);
|
|
Packit |
ae9e2a |
cl_assert(giterr_last() != NULL);
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_branches_remote__local_remote_returns_error(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
const char *local = "refs/heads/master";
|
|
Packit |
ae9e2a |
git_buf buf;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
giterr_clear();
|
|
Packit |
ae9e2a |
memset(&buf, 0, sizeof(git_buf));
|
|
Packit |
ae9e2a |
cl_git_fail_with(git_branch_remote_name(&buf, g_repo, local), GIT_ERROR);
|
|
Packit |
ae9e2a |
cl_assert(giterr_last() != NULL);
|
|
Packit |
ae9e2a |
}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
void test_refs_branches_remote__ambiguous_remote_returns_error(void)
|
|
Packit |
ae9e2a |
{
|
|
Packit |
ae9e2a |
git_remote *remote;
|
|
Packit |
ae9e2a |
git_buf buf;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/* Create the remote */
|
|
Packit |
ae9e2a |
cl_git_pass(git_remote_create_with_fetchspec(&remote, g_repo, "addtest", "http://github.com/libgit2/libgit2", "refs/heads/*:refs/remotes/test/*"));
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
git_remote_free(remote);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
giterr_clear();
|
|
Packit |
ae9e2a |
memset(&buf, 0, sizeof(git_buf));
|
|
Packit |
ae9e2a |
cl_git_fail_with(git_branch_remote_name(&buf, g_repo, remote_tracking_branch_name), GIT_EAMBIGUOUS);
|
|
Packit |
ae9e2a |
cl_assert(giterr_last() != NULL);
|
|
Packit |
ae9e2a |
}
|