Commit | Line | Data |
576d59a0 |
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::FromDirectoryRecursive' } |
17 | |
18 | my $repo_dir = "$Bin/lib/repositories"; |
19 | my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo_dir ); |
20 | isa_ok($repo, 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive'); |
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 | |
26 | my $repository_list = $repo->repositories; |
27 | ok(scalar @{$repository_list} == 5, '->repositories is an array with the correct number of members' ); |
28 | isa_ok($repository_list->[0], 'Gitalist::Git::Repository'); |
29 | is($repository_list->[0]->{name}, 'bare.git', '->repositories has correct name for "bare.git" repo' ); |
30 | |
31 | dies_ok { |
32 | my $repository = $repo->get_repository('NoSuchRepository'); |
33 | } 'throws exception for invalid repository'; |
34 | |
35 | dies_ok { |
36 | my $repository = $repo->get_repository(); |
37 | } 'throws exception for no repository'; |
38 | |
39 | dies_ok { |
40 | my $repository = $repo->get_repository('../../../'); |
41 | } 'throws exception for directory traversal'; |
42 | |
43 | my $repository = $repo->get_repository('repo1'); |
44 | isa_ok($repository, 'Gitalist::Git::Repository'); |
45 | |
46 | |
47 | # check for bug where get_repository blew up if repo_dir |
48 | # was a relative path |
49 | lives_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'; |