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