No need for addtional variable.
[catagits/Gitalist.git] / t / 02git_CollectionOfRepositories_FromDirectoryRecursive.t
CommitLineData
576d59a0 1use FindBin qw/$Bin/;
2BEGIN {
3 my $env = "$FindBin::Bin/script/env";
4 if (-r $env) {
5 do $env or die $@;
6 }
7}
8
9use strict;
10use warnings;
11use Test::More qw/no_plan/;
12use Test::Exception;
13
14use Data::Dumper;
15
16BEGIN { use_ok 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive' }
17
18my $repo_dir = "$Bin/lib/repositories";
19my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo_dir );
20isa_ok($repo, 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive');
21
22is($repo->repo_dir, $repo_dir, "repo->repo_dir is correct" );
23
24# 'bare.git' is a bare git repository in the repository dir
25
26my $repository_list = $repo->repositories;
27ok(scalar @{$repository_list} == 5, '->repositories is an array with the correct number of members' );
28isa_ok($repository_list->[0], 'Gitalist::Git::Repository');
29is($repository_list->[0]->{name}, 'bare.git', '->repositories has correct name for "bare.git" repo' );
30
31dies_ok {
32 my $repository = $repo->get_repository('NoSuchRepository');
33} 'throws exception for invalid repository';
34
35dies_ok {
36 my $repository = $repo->get_repository();
37} 'throws exception for no repository';
38
39dies_ok {
40 my $repository = $repo->get_repository('../../../');
41} 'throws exception for directory traversal';
42
43my $repository = $repo->get_repository('repo1');
44isa_ok($repository, 'Gitalist::Git::Repository');
45
46
47# check for bug where get_repository blew up if repo_dir
48# was a relative path
49lives_ok {
50 my $repo2_dir = "$Bin/lib/../lib/repositories";
51 my $repo2 = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo2_dir );
52 my $repo2_proj = $repo2->get_repository('repo1');
53} 'relative repo_dir properly handled';