Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/libgit2.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorVicent Martí <tanoku@gmail.com>2011-07-05 15:31:37 +0400
committerVicent Martí <tanoku@gmail.com>2011-07-05 15:31:37 +0400
commitf12aa9dc5ed04cfe92f1d536314eb03185f67f7d (patch)
treeb720325beef678f7d132280d8f2644277a4e7d86 /tests
parent7d69f78897fc079a58059d9a84ab5928161d78cb (diff)
parent0ac2726fdf945792028e59105d8630a91c5d3663 (diff)
Merge pull request #300 from carlosmn/gsoc2011/master
A bit of networking
Diffstat (limited to 'tests')
-rw-r--r--tests/resources/testrepo.git/config3
-rw-r--r--tests/t16-remotes.c106
-rw-r--r--tests/test_main.c2
3 files changed, 111 insertions, 0 deletions
diff --git a/tests/resources/testrepo.git/config b/tests/resources/testrepo.git/config
index 2f8958058..1a5aacdfa 100644
--- a/tests/resources/testrepo.git/config
+++ b/tests/resources/testrepo.git/config
@@ -3,3 +3,6 @@
filemode = true
bare = true
logallrefupdates = true
+[remote "test"]
+ url = git://github.com/libgit2/libgit2
+ fetch = +refs/heads/*:refs/remotes/test/*
diff --git a/tests/t16-remotes.c b/tests/t16-remotes.c
new file mode 100644
index 000000000..4bc2f55d7
--- /dev/null
+++ b/tests/t16-remotes.c
@@ -0,0 +1,106 @@
+/*
+ * This file is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2,
+ * as published by the Free Software Foundation.
+ *
+ * In addition to the permissions in the GNU General Public License,
+ * the authors give you unlimited permission to link the compiled
+ * version of this file into combinations with other programs,
+ * and to distribute those combinations without any restriction
+ * coming from the use of this file. (The General Public License
+ * restrictions do apply in other respects; for example, they cover
+ * modification of the file, and distribution when not linked into
+ * a combined executable.)
+ *
+ * This file is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; see the file COPYING. If not, write to
+ * the Free Software Foundation, 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+#include "test_lib.h"
+#include "test_helpers.h"
+
+#include <git2.h>
+
+BEGIN_TEST(remotes0, "remote parsing works")
+ git_remote *remote;
+ git_repository *repo;
+ git_config *cfg;
+
+ must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
+ must_pass(git_repository_config(&cfg, repo, NULL, NULL));
+ must_pass(git_remote_get(&remote, cfg, "test"));
+ must_be_true(!strcmp(git_remote_name(remote), "test"));
+ must_be_true(!strcmp(git_remote_url(remote), "git://github.com/libgit2/libgit2"));
+
+ git_remote_free(remote);
+ git_config_free(cfg);
+ git_repository_free(repo);
+END_TEST
+
+BEGIN_TEST(refspec0, "remote with refspec works")
+ git_remote *remote;
+ git_repository *repo;
+ git_config *cfg;
+ const git_refspec *refspec = NULL;
+
+ must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
+ must_pass(git_repository_config(&cfg, repo, NULL, NULL));
+ must_pass(git_remote_get(&remote, cfg, "test"));
+ refspec = git_remote_fetchspec(remote);
+ must_be_true(refspec != NULL);
+ must_be_true(!strcmp(git_refspec_src(refspec), "refs/heads/*"));
+ must_be_true(!strcmp(git_refspec_dst(refspec), "refs/remotes/test/*"));
+ git_remote_free(remote);
+ git_config_free(cfg);
+ git_repository_free(repo);
+END_TEST
+
+BEGIN_TEST(refspec1, "remote fnmatch works as expected")
+ git_remote *remote;
+ git_repository *repo;
+ git_config *cfg;
+ const git_refspec *refspec = NULL;
+
+ must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
+ must_pass(git_repository_config(&cfg, repo, NULL, NULL));
+ must_pass(git_remote_get(&remote, cfg, "test"));
+ refspec = git_remote_fetchspec(remote);
+ must_be_true(refspec != NULL);
+ must_pass(git_refspec_src_match(refspec, "refs/heads/master"));
+ must_pass(git_refspec_src_match(refspec, "refs/heads/multi/level/branch"));
+ git_remote_free(remote);
+ git_config_free(cfg);
+ git_repository_free(repo);
+END_TEST
+
+BEGIN_TEST(refspec2, "refspec transform")
+ git_remote *remote;
+ git_repository *repo;
+ git_config *cfg;
+ const git_refspec *refspec = NULL;
+ char ref[1024] = {0};
+
+ must_pass(git_repository_open(&repo, REPOSITORY_FOLDER));
+ must_pass(git_repository_config(&cfg, repo, NULL, NULL));
+ must_pass(git_remote_get(&remote, cfg, "test"));
+ refspec = git_remote_fetchspec(remote);
+ must_be_true(refspec != NULL);
+ must_pass(git_refspec_transform(ref, sizeof(ref), refspec, "refs/heads/master"));
+ must_be_true(!strcmp(ref, "refs/remotes/test/master"));
+ git_remote_free(remote);
+ git_config_free(cfg);
+ git_repository_free(repo);
+END_TEST
+
+BEGIN_SUITE(remotes)
+ ADD_TEST(remotes0)
+ ADD_TEST(refspec0)
+ ADD_TEST(refspec1)
+ ADD_TEST(refspec2)
+END_SUITE
diff --git a/tests/test_main.c b/tests/test_main.c
index 3fd117d0b..aab6c068b 100644
--- a/tests/test_main.c
+++ b/tests/test_main.c
@@ -43,6 +43,7 @@ DECLARE_SUITE(refs);
DECLARE_SUITE(repository);
DECLARE_SUITE(threads);
DECLARE_SUITE(config);
+DECLARE_SUITE(remotes);
static libgit2_suite suite_methods[]= {
SUITE_NAME(core),
@@ -59,6 +60,7 @@ static libgit2_suite suite_methods[]= {
SUITE_NAME(repository),
SUITE_NAME(threads),
SUITE_NAME(config),
+ SUITE_NAME(remotes),
};
#define GIT_SUITE_COUNT (ARRAY_SIZE(suite_methods))