Fix for infinite loop bug in blame.
[catagits/Gitalist.git] / t / 02git_CollectionOfRepositories_FromDirectory.t
CommitLineData
5ed74c87 1use FindBin qw/$Bin/;
df629266 2BEGIN {
0556ab26 3 my $env = "$FindBin::Bin/../script/env";
df629266 4 if (-r $env) {
5 do $env or die $@;
6 }
7}
8
56b6dbe6 9use strict;
10use warnings;
56b6dbe6 11use Test::More qw/no_plan/;
3bbb1202 12use Test::Exception;
56b6dbe6 13
14use Data::Dumper;
15
cd169152 16BEGIN { use_ok 'Gitalist::Git::CollectionOfRepositories::FromDirectory' }
56b6dbe6 17
58251520 18my $repo_dir = "$Bin/lib/repositories";
cd169152 19my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectory->new( repo_dir => $repo_dir );
20isa_ok($repo, 'Gitalist::Git::CollectionOfRepositories::FromDirectory');
56b6dbe6 21
4baaeeef 22is($repo->repo_dir, $repo_dir, "repo->repo_dir is correct" );
56b6dbe6 23
85762693 24# 'bare.git' is a bare git repository in the repository dir
25use Path::Class;
26my $repoBare = Path::Class::Dir->new('t/lib/repositories/bare.git');
27ok( $repo->_is_git_repo( $repoBare ), 'is_git_repo true for bare git repo' );
28
85762693 29# 'empty.git' is an empty directory in the repository dir
30my $repoEmpty = Path::Class::Dir->new('t/lib/repositories/empty.git');
31ok( ! $repo->_is_git_repo( $repoEmpty ), 'is_git_repo is false for empty dir' );
32
82bc0f05 33my $repository_list = $repo->repositories;
34ok(scalar @{$repository_list} == 3, '->repositories is an array with the correct number of members' );
35isa_ok($repository_list->[0], 'Gitalist::Git::Repository');
36is($repository_list->[0]->{name}, 'bare.git', '->repositories has correct name for "bare.git" repo' );
ba033c36 37
3bbb1202 38dies_ok {
82bc0f05 39 my $repository = $repo->get_repository('NoSuchRepository');
40} 'throws exception for invalid repository';
3bbb1202 41
42dies_ok {
82bc0f05 43 my $repository = $repo->get_repository();
44} 'throws exception for no repository';
3bbb1202 45
5232dbdd 46dies_ok {
82bc0f05 47 my $repository = $repo->get_repository('../../../');
5232dbdd 48} 'throws exception for directory traversal';
49
82bc0f05 50my $repository = $repo->get_repository('repo1');
51isa_ok($repository, 'Gitalist::Git::Repository');
ca6e3675 52
53
b5ce0e6a 54# check for bug where get_repository blew up if repo_dir
ca6e3675 55# was a relative path
56lives_ok {
57 my $repo2_dir = "$Bin/lib/../lib/repositories";
cd169152 58 my $repo2 = Gitalist::Git::CollectionOfRepositories::FromDirectory->new( repo_dir => $repo2_dir );
b5ce0e6a 59 my $repo2_proj = $repo2->get_repository('repo1');
ca6e3675 60} 'relative repo_dir properly handled';
1d727634 61
62my $repo_eok = Gitalist::Git::CollectionOfRepositories::FromDirectory->new(
63 repo_dir => $repo_dir,
64 export_ok => 'export-ok',
65);
66
67my @eok_repos = @{$repo_eok->repositories};
68
69is(1, @eok_repos, "Found the 1 export-ok repo");
70is('repo1', $eok_repos[0]->name, "Found repo1 export-ok repo");