Do the correct thing with type contraints etc to be able to serialize things
[catagits/Gitalist.git] / t / 02git_Repository.t
CommitLineData
56b6dbe6 1use strict;
2use warnings;
3use FindBin qw/$Bin/;
4use Test::More qw/no_plan/;
b5b638f7 5use Test::Exception;
5effb2c9 6use Test::utf8;
7use Encode qw/decode_utf8/;
56b6dbe6 8use Data::Dumper;
9
5effb2c9 10BEGIN {
11 # Mocking to allow testing regardless of the user's locale
12 require I18N::Langinfo;
13 no warnings 'redefine';
14 *I18N::Langinfo::langinfo = sub($) {
15 return "UTF-8" if $_[0] == I18N::Langinfo::CODESET();
16 };
17 *CORE::GLOBAL::getpwuid = sub {
18 wantarray
19 ? ("test", "x", "1000", "1000", "", "", "T\x{c3}\x{a9}st", "/home/test", "/bin/bash")
20 : "test";
21 };
22}
23
44a9ed75 24BEGIN { use_ok 'Gitalist::Git::Repository' }
56b6dbe6 25
b5b638f7 26dies_ok {
44a9ed75 27 my $proj = Gitalist::Git::Repository->new();
82bc0f05 28} 'New repository with no args';
b5b638f7 29
56b6dbe6 30use Path::Class;
58251520 31my $gitdir = dir("$Bin/lib/repositories/repo1");
4baaeeef 32
44a9ed75 33my $proj = Gitalist::Git::Repository->new($gitdir);
34isa_ok($proj, 'Gitalist::Git::Repository');
82bc0f05 35is($proj->path, $gitdir, 'repository path is set');
36isa_ok($proj->path, 'Path::Class::Dir', 'repository path');
56b6dbe6 37is($proj->name, qw/repo1/, 'repository name is set');
38is($proj->description, qq/some test repository/, 'repository description loaded');
39isa_ok($proj->last_change, 'DateTime', 'last_change');
dbcc98a9 40{
41 my $packed = $proj->pack;
42 use Data::Dumper;
43 warn Dumper $packed;
44}
d47734bf 45
46is_deeply $proj->pack, {
47 '__CLASS__' => 'Gitalist::Git::Repository',
48 'is_bare' => 1,
49 'owner' => "T\x{e9}st",
50 'last_change' => '2009-11-12T19:00:34Z',
51 'name' => 'repo1',
52 'description' => 'some test repository'
53};
56b6dbe6 54
c65cccc2 55my %references = %{$proj->references};
56ok(keys %references >= 2, '->references hash has elements');
57is($references{'36c6c6708b8360d7023e8a1649c45bcf9b3bd818'}->[0], 'heads/master', 'reference looks ok');
58my @heads = @{$proj->heads};
c73be54e 59ok(scalar @heads > 1, '->heads list has more than one element');
60my %head = %{$heads[1]};
61ok(keys %head == 3, '->heads[1] has the right number of keys');
62ok(defined $head{sha1}, '->heads[1]-sha1 is defined');
63ok(defined $head{name}, '->heads[1]-name is defined');
839da3d7 64is($proj->head_hash, '36c6c6708b8360d7023e8a1649c45bcf9b3bd818', 'head_hash for HEAD is correct');
65is($proj->head_hash('refs/heads/master'), '36c6c6708b8360d7023e8a1649c45bcf9b3bd818', 'head_hash for refs/heads/master is correct');
66is($proj->head_hash('rafs/head/mister'), undef, 'head_hash for rafs/head/mister is undef');
a8a8f8f9 67
68is(scalar $proj->list_tree, 2, 'expected number of entries in tree');
54368e9d 69isa_ok(($proj->list_tree)[1], 'Gitalist::Git::Object');
70
71# Return an ::Object from a sha1
467fa7d9 72my $obj1 = $proj->get_object('729a7c3f6ba5453b42d16a43692205f67fb23bc1');
e1307124 73isa_ok($obj1, 'Gitalist::Git::Object::Tree');
54368e9d 74
fc11c7f1 75my $hbp_sha1 = $proj->hash_by_path('36c6c6708b8360d7023e8a1649c45bcf9b3bd818', 'dir1/file2');
76my $obj2 = $proj->get_object($hbp_sha1);
e1307124 77isa_ok($obj2, 'Gitalist::Git::Object::Blob');
fc11c7f1 78is($obj2->type, 'blob', 'hash_by_path obj is a file');
56908878 79is($obj2->content, "foo\n", 'hash_by_path obj is a file');
85762693 80
e1307124 81my $obj3 = $proj->get_object($proj->head_hash);
82isa_ok($obj3, 'Gitalist::Git::Object::Commit');
83
85762693 84like($proj->head_hash('HEAD'), qr/^([0-9a-fA-F]{40})$/, 'head_hash');
85
86{
87 my @tree = $proj->list_tree('3bc0634310b9c62222bb0e724c11ffdfb297b4ac');
88 is(scalar @tree, 1, "tree array contains one entry.");
e75df318 89 isa_ok($tree[0], 'Gitalist::Git::Object', 'tree element 0');
85762693 90}
91
5effb2c9 92my $owner = $proj->owner;
93is_flagged_utf8($owner, "Owner name is flagged as utf8");
94is_sane_utf8($owner, "Owner name is not double-encoded");
95is($owner, decode_utf8("T\x{c3}\x{a9}st"), "Owner name is correct");