Blame tests/object/tag/read.c

Packit Service 20376f
#include "clar_libgit2.h"
Packit Service 20376f
Packit Service 20376f
#include "tag.h"
Packit Service 20376f
Packit Service 20376f
static const char *tag1_id = "b25fa35b38051e4ae45d4222e795f9df2e43f1d1";
Packit Service 20376f
static const char *tag2_id = "7b4384978d2493e851f9cca7858815fac9b10980";
Packit Service 20376f
static const char *tagged_commit = "e90810b8df3e80c413d903f631643c716887138d";
Packit Service 20376f
static const char *bad_tag_id = "eda9f45a2a98d4c17a09d681d88569fa4ea91755";
Packit Service 20376f
static const char *badly_tagged_commit = "e90810b8df3e80c413d903f631643c716887138d";
Packit Service 20376f
static const char *short_tag_id = "5da7760512a953e3c7c4e47e4392c7a4338fb729";
Packit Service 20376f
static const char *short_tagged_commit = "4a5ed60bafcf4638b7c8356bd4ce1916bfede93c";
Packit Service 20376f
static const char *taggerless = "4a23e2e65ad4e31c4c9db7dc746650bfad082679";
Packit Service 20376f
Packit Service 20376f
static git_repository *g_repo;
Packit Service 20376f
Packit Service 20376f
// Fixture setup and teardown
Packit Service 20376f
void test_object_tag_read__initialize(void)
Packit Service 20376f
{
Packit Service 20376f
	g_repo = cl_git_sandbox_init("testrepo");
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_object_tag_read__cleanup(void)
Packit Service 20376f
{
Packit Service 20376f
	cl_git_sandbox_cleanup();
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
Packit Service 20376f
void test_object_tag_read__parse(void)
Packit Service 20376f
{
Packit Service 20376f
	// read and parse a tag from the repository
Packit Service 20376f
	git_tag *tag1, *tag2;
Packit Service 20376f
	git_commit *commit;
Packit Service 20376f
	git_oid id1, id2, id_commit;
Packit Service 20376f
Packit Service 20376f
	git_oid_fromstr(&id1, tag1_id);
Packit Service 20376f
	git_oid_fromstr(&id2, tag2_id);
Packit Service 20376f
	git_oid_fromstr(&id_commit, tagged_commit);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_lookup(&tag1, g_repo, &id1));
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_s(git_tag_name(tag1), "test");
Packit Service 20376f
	cl_assert(git_tag_target_type(tag1) == GIT_OBJ_TAG);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_target((git_object **)&tag2, tag1));
Packit Service 20376f
	cl_assert(tag2 != NULL);
Packit Service 20376f
Packit Service 20376f
	cl_assert(git_oid_cmp(&id2, git_tag_id(tag2)) == 0);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_target((git_object **)&commit, tag2));
Packit Service 20376f
	cl_assert(commit != NULL);
Packit Service 20376f
Packit Service 20376f
	cl_assert(git_oid_cmp(&id_commit, git_commit_id(commit)) == 0);
Packit Service 20376f
Packit Service 20376f
	git_tag_free(tag1);
Packit Service 20376f
	git_tag_free(tag2);
Packit Service 20376f
	git_commit_free(commit);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_object_tag_read__parse_without_tagger(void)
Packit Service 20376f
{
Packit Service 20376f
	// read and parse a tag without a tagger field
Packit Service 20376f
	git_repository *bad_tag_repo;
Packit Service 20376f
	git_tag *bad_tag;
Packit Service 20376f
	git_commit *commit;
Packit Service 20376f
	git_oid id, id_commit;
Packit Service 20376f
Packit Service 20376f
	// TODO: This is a little messy
Packit Service 20376f
	cl_git_pass(git_repository_open(&bad_tag_repo, cl_fixture("bad_tag.git")));
Packit Service 20376f
Packit Service 20376f
	git_oid_fromstr(&id, bad_tag_id);
Packit Service 20376f
	git_oid_fromstr(&id_commit, badly_tagged_commit);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_lookup(&bad_tag, bad_tag_repo, &id));
Packit Service 20376f
	cl_assert(bad_tag != NULL);
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_s(git_tag_name(bad_tag), "e90810b");
Packit Service 20376f
	cl_assert(git_oid_cmp(&id, git_tag_id(bad_tag)) == 0);
Packit Service 20376f
	cl_assert(bad_tag->tagger == NULL);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_target((git_object **)&commit, bad_tag));
Packit Service 20376f
	cl_assert(commit != NULL);
Packit Service 20376f
Packit Service 20376f
	cl_assert(git_oid_cmp(&id_commit, git_commit_id(commit)) == 0);
Packit Service 20376f
Packit Service 20376f
Packit Service 20376f
	git_tag_free(bad_tag);
Packit Service 20376f
	git_commit_free(commit);
Packit Service 20376f
	git_repository_free(bad_tag_repo);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_object_tag_read__parse_without_message(void)
Packit Service 20376f
{
Packit Service 20376f
	// read and parse a tag without a message field
Packit Service 20376f
	git_repository *short_tag_repo;
Packit Service 20376f
	git_tag *short_tag;
Packit Service 20376f
	git_commit *commit;
Packit Service 20376f
	git_oid id, id_commit;
Packit Service 20376f
Packit Service 20376f
	// TODO: This is a little messy
Packit Service 20376f
	cl_git_pass(git_repository_open(&short_tag_repo, cl_fixture("short_tag.git")));
Packit Service 20376f
Packit Service 20376f
	git_oid_fromstr(&id, short_tag_id);
Packit Service 20376f
	git_oid_fromstr(&id_commit, short_tagged_commit);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_lookup(&short_tag, short_tag_repo, &id));
Packit Service 20376f
	cl_assert(short_tag != NULL);
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_s(git_tag_name(short_tag), "no_description");
Packit Service 20376f
	cl_assert(git_oid_cmp(&id, git_tag_id(short_tag)) == 0);
Packit Service 20376f
	cl_assert(short_tag->message == NULL);
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_target((git_object **)&commit, short_tag));
Packit Service 20376f
	cl_assert(commit != NULL);
Packit Service 20376f
Packit Service 20376f
	cl_assert(git_oid_cmp(&id_commit, git_commit_id(commit)) == 0);
Packit Service 20376f
Packit Service 20376f
	git_tag_free(short_tag);
Packit Service 20376f
	git_commit_free(commit);
Packit Service 20376f
	git_repository_free(short_tag_repo);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
void test_object_tag_read__without_tagger_nor_message(void)
Packit Service 20376f
{
Packit Service 20376f
	git_tag *tag;
Packit Service 20376f
	git_oid id;
Packit Service 20376f
	git_repository *repo;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_repository_open(&repo, cl_fixture("testrepo.git")));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_oid_fromstr(&id, taggerless));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_tag_lookup(&tag, repo, &id));
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_s(git_tag_name(tag), "taggerless");
Packit Service 20376f
	cl_assert(git_tag_target_type(tag) == GIT_OBJ_COMMIT);
Packit Service 20376f
Packit Service 20376f
	cl_assert(tag->message == NULL);
Packit Service 20376f
	cl_assert(tag->tagger == NULL);
Packit Service 20376f
Packit Service 20376f
	git_tag_free(tag);
Packit Service 20376f
	git_repository_free(repo);
Packit Service 20376f
}
Packit Service 20376f
Packit Service 20376f
static const char *silly_tag = "object c054ccaefbf2da31c3b19178f9e3ef20a3867924\n\
Packit Service 20376f
type commit\n\
Packit Service 20376f
tag v1_0_1\n\
Packit Service 20376f
tagger Jamis Buck <jamis@37signals.com> 1107717917\n\
Packit Service 20376f
diff --git a/lib/sqlite3/version.rb b/lib/sqlite3/version.rb\n\
Packit Service 20376f
index 0b3bf69..4ee8fc2 100644\n\
Packit Service 20376f
--- a/lib/sqlite3/version.rb\n\
Packit Service 20376f
+++ b/lib/sqlite3/version.rb\n\
Packit Service 20376f
@@ -36,7 +36,7 @@ module SQLite3\n\
Packit Service 20376f
 \n\
Packit Service 20376f
     MAJOR = 1\n\
Packit Service 20376f
     MINOR = 0\n\
Packit Service 20376f
-    TINY  = 0\n\
Packit Service 20376f
+    TINY  = 1\n\
Packit Service 20376f
 \n\
Packit Service 20376f
     STRING = [ MAJOR, MINOR, TINY ].join( \".\" )\n\
Packit Service 20376f
 \n\
Packit Service 20376f
 -0600\n\
Packit Service 20376f
\n\
Packit Service 20376f
v1_0_1 release\n";
Packit Service 20376f
Packit Service 20376f
void test_object_tag_read__extra_header_fields(void)
Packit Service 20376f
{
Packit Service 20376f
	git_tag *tag;
Packit Service 20376f
	git_odb *odb;
Packit Service 20376f
	git_oid id;
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_repository_odb__weakptr(&odb, g_repo));
Packit Service 20376f
Packit Service 20376f
	cl_git_pass(git_odb_write(&id, odb, silly_tag, strlen(silly_tag), GIT_OBJ_TAG));
Packit Service 20376f
	cl_git_pass(git_tag_lookup(&tag, g_repo, &id));
Packit Service 20376f
Packit Service 20376f
	cl_assert_equal_s("v1_0_1 release\n", git_tag_message(tag));
Packit Service 20376f
Packit Service 20376f
	git_tag_free(tag);
Packit Service 20376f
}