paths need to be nativized uniformly
[catagits/Gitalist.git] / t / 02git_CollectionOfRepositories_FromDirectoryRecursive.t
CommitLineData
576d59a0 1use FindBin qw/$Bin/;
2BEGIN {
541f5153 3 my $env = "$FindBin::Bin/../script/env";
576d59a0 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;
b40da3c6 13use Path::Class::Dir;
7b5bdee0 14use Path::Class qw' file dir ';
576d59a0 15
16BEGIN { use_ok 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive' }
17
7b5bdee0 18my $repo_dir = dir( "$Bin/lib/repositories" );
576d59a0 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;
cbc1a311 27is( scalar @{$repository_list}, 6, '->repositories is an array with the correct number of members' );
576d59a0 28isa_ok($repository_list->[0], 'Gitalist::Git::Repository');
7b5bdee0 29my @expected_names = sort map file($_)->stringify, qw( bare.git recursive/barerecursive.git nodescription repo1 recursive/goingdeeper/scratch.git recursive/goingdeeper2/scratch.git);
411e6add 30my @sorted_names = sort map { $_->{name} } @{$repository_list};
7b5bdee0 31is_deeply( \@sorted_names, \@expected_names , 'Repositories are correctly loaded' );
32
33my $get_repo_from_native_name = sub { $repo->get_repository( dir( $_[0] )->stringify ) };
576d59a0 34
35dies_ok {
7b5bdee0 36 my $repository = $get_repo_from_native_name->( "NoSuchRepository" );
576d59a0 37} 'throws exception for invalid repository';
38
39dies_ok {
7b5bdee0 40 my $repository = $repo->get_repository;
576d59a0 41} 'throws exception for no repository';
42
43dies_ok {
7b5bdee0 44 my $repository = $get_repo_from_native_name->( '../../../' );
411e6add 45} 'Relative directory not contained within repo_dir';
576d59a0 46
7b5bdee0 47my $repository = $get_repo_from_native_name->( "repo1" );
576d59a0 48isa_ok($repository, 'Gitalist::Git::Repository');
df2728e1 49
7b5bdee0 50$repository = $get_repo_from_native_name->( "recursive/goingdeeper/scratch.git" );
df2728e1 51isa_ok($repository, 'Gitalist::Git::Repository');
e522f1de 52cmp_ok($repository->description, 'eq', 'goingdeeper/scratch.git repo', 'Got the right repo');
53
7b5bdee0 54$repository = $get_repo_from_native_name->( "recursive/goingdeeper2/scratch.git" );
e522f1de 55isa_ok($repository, 'Gitalist::Git::Repository');
56cmp_ok($repository->description, 'eq', 'goingdeeper2/scratch.git repo', 'Got the right repo');
57
576d59a0 58
576d59a0 59# check for bug where get_repository blew up if repo_dir
60# was a relative path
61lives_ok {
411e6add 62 my $repo2_dir = "$Bin/lib/../lib/repositories";
63 my $repo2 = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo2_dir );
cbc1a311 64
7b5bdee0 65 my $repo2_proj = $repo2->get_repository( dir( "repo1" )->stringify );
576d59a0 66} 'relative repo_dir properly handled';