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