X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F02git_Repository.t;h=ba86a79870fa5cd4e46a07446a5398059522c3fe;hb=d3f6e5216862e0b679891259b2b2ea5f31cf0674;hp=4b5fd208a51130e535156dc869b61be27443cbba;hpb=df6292661bd22bb00ba89f0684b60bb8096383c8;p=catagits%2FGitalist.git diff --git a/t/02git_Repository.t b/t/02git_Repository.t index 4b5fd20..ba86a79 100644 --- a/t/02git_Repository.t +++ b/t/02git_Repository.t @@ -1,6 +1,6 @@ use FindBin qw/$Bin/; BEGIN { - my $env = "$FindBin::Bin/script/env"; + my $env = "$FindBin::Bin/../script/env"; if (-r $env) { do $env or die $@; } @@ -50,34 +50,31 @@ ok(keys %references >= 2, '->references hash has elements'); is($references{'36c6c6708b8360d7023e8a1649c45bcf9b3bd818'}->[0], 'heads/master', 'reference looks ok'); my @heads = @{$proj->heads}; ok(scalar @heads > 1, '->heads list has more than one element'); -my %head = %{$heads[1]}; -ok(keys %head == 3, '->heads[1] has the right number of keys'); -ok(defined $head{sha1}, '->heads[1]-sha1 is defined'); -ok(defined $head{name}, '->heads[1]-name is defined'); +my $head = $heads[1]; +isa_ok($head, 'Gitalist::Git::Head'); is($proj->head_hash, '36c6c6708b8360d7023e8a1649c45bcf9b3bd818', 'head_hash for HEAD is correct'); is($proj->head_hash('refs/heads/master'), '36c6c6708b8360d7023e8a1649c45bcf9b3bd818', 'head_hash for refs/heads/master is correct'); is($proj->head_hash('rafs/head/mister'), undef, 'head_hash for rafs/head/mister is undef'); -is(scalar $proj->list_tree, 2, 'expected number of entries in tree'); -isa_ok(($proj->list_tree)[1], 'Gitalist::Git::Object'); +ok(scalar @{$proj->tags} == 1, '->tags list has one element'); # Return an ::Object from a sha1 my $obj1 = $proj->get_object('729a7c3f6ba5453b42d16a43692205f67fb23bc1'); isa_ok($obj1, 'Gitalist::Git::Object::Tree'); -my $hbp_sha1 = $proj->hash_by_path('36c6c6708b8360d7023e8a1649c45bcf9b3bd818', 'dir1/file2'); -my $obj2 = $proj->get_object($hbp_sha1); -isa_ok($obj2, 'Gitalist::Git::Object::Blob'); -is($obj2->type, 'blob', 'hash_by_path obj is a file'); -is($obj2->content, "foo\n", 'hash_by_path obj is a file'); - my $obj3 = $proj->get_object($proj->head_hash); isa_ok($obj3, 'Gitalist::Git::Object::Commit'); +my $obj2 = $obj3->sha_by_path('dir1/file2'); +isa_ok($obj2, 'Gitalist::Git::Object::Blob'); +is($obj2->type, 'blob', 'sha_by_path obj is a blob'); +is($obj2->content, "foo\n", 'sha_by_path obj content is correct'); + + like($proj->head_hash('HEAD'), qr/^([0-9a-fA-F]{40})$/, 'head_hash'); { - my @tree = $proj->list_tree('3bc0634310b9c62222bb0e724c11ffdfb297b4ac'); + my @tree = @{$obj3->tree}; is(scalar @tree, 1, "tree array contains one entry."); isa_ok($tree[0], 'Gitalist::Git::Object', 'tree element 0'); } @@ -86,3 +83,46 @@ my $owner = $proj->owner; is_flagged_utf8($owner, "Owner name is flagged as utf8"); is_sane_utf8($owner, "Owner name is not double-encoded"); is($owner, decode_utf8("T\x{c3}\x{a9}st"), "Owner name is correct"); + +is_deeply $proj->pack, { + __CLASS__ => 'Gitalist::Git::Repository', + description => 'some test repository', + heads => [ + { + __CLASS__ => 'Gitalist::Git::Head', + committer => 'Zachary Stevens ', + last_change => '2009-11-12T19:00:34Z', + name => 'branch1', + sha1 => '0710a7c8ee11c73e8098d08f9384c2a839c65e4e' + }, + { + __CLASS__ => 'Gitalist::Git::Head', + committer => 'Florian Ragwitz ', + last_change => '2007-03-06T20:44:35Z', + name => 'master', + sha1 => '36c6c6708b8360d7023e8a1649c45bcf9b3bd818' + } + ], + is_bare => 1, + last_change => '2009-11-12T19:00:34Z', + name => 'repo1', + owner => "T\351st", + references => { + "36c6c6708b8360d7023e8a1649c45bcf9b3bd818" => [ + 'heads/master', + 'tags/0.01' + ], + "0710a7c8ee11c73e8098d08f9384c2a839c65e4e" => [ 'heads/branch1' ] + }, + tags => [ { + __CLASS__ + => 'Gitalist::Git::Tag', + committer + => 'Florian Ragwitz ', + last_change + => '2007-03-06T20:44:35Z', + name => 0.01, + sha1 => '36c6c6708b8360d7023e8a1649c45bcf9b3bd818', + type => 'commit' + } ] +}, 'Serialized correctly';