X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F02git_CollectionOfRepositories_FromDirectoryRecursive.t;h=4bd57997df88f4ead5bb64eef6db34ee334ea4ae;hb=7b5bdee05283b67c7ee10d8c150ab19fec335541;hp=f3bba67912b03bb0999c1a3f4cbeaa53f1aab191;hpb=b40da3c697925c41357780480622000c32c58e28;p=catagits%2FGitalist.git diff --git a/t/02git_CollectionOfRepositories_FromDirectoryRecursive.t b/t/02git_CollectionOfRepositories_FromDirectoryRecursive.t index f3bba67..4bd5799 100644 --- a/t/02git_CollectionOfRepositories_FromDirectoryRecursive.t +++ b/t/02git_CollectionOfRepositories_FromDirectoryRecursive.t @@ -1,6 +1,6 @@ use FindBin qw/$Bin/; BEGIN { - my $env = "$FindBin::Bin/script/env"; + my $env = "$FindBin::Bin/../script/env"; if (-r $env) { do $env or die $@; } @@ -11,10 +11,11 @@ use warnings; use Test::More qw/no_plan/; use Test::Exception; use Path::Class::Dir; +use Path::Class qw' file dir '; BEGIN { use_ok 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive' } -my $repo_dir = "$Bin/lib/repositories"; +my $repo_dir = dir( "$Bin/lib/repositories" ); my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo_dir ); isa_ok($repo, 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive'); @@ -23,40 +24,43 @@ is($repo->repo_dir, $repo_dir, "repo->repo_dir is correct" ); # 'bare.git' is a bare git repository in the repository dir my $repository_list = $repo->repositories; -is( scalar @{$repository_list}, 5, '->repositories is an array with the correct number of members' ); +is( scalar @{$repository_list}, 6, '->repositories is an array with the correct number of members' ); isa_ok($repository_list->[0], 'Gitalist::Git::Repository'); +my @expected_names = sort map file($_)->stringify, qw( bare.git recursive/barerecursive.git nodescription repo1 recursive/goingdeeper/scratch.git recursive/goingdeeper2/scratch.git); my @sorted_names = sort map { $_->{name} } @{$repository_list}; -is_deeply( \@sorted_names, [ qw( bare.git barerecursive.git nodescription repo1 scratch.git) ], 'Repositories are correctly loaded' ); +is_deeply( \@sorted_names, \@expected_names , 'Repositories are correctly loaded' ); + +my $get_repo_from_native_name = sub { $repo->get_repository( dir( $_[0] )->stringify ) }; dies_ok { - my $repository = $repo->get_repository("NoSuchRepository"); + my $repository = $get_repo_from_native_name->( "NoSuchRepository" ); } 'throws exception for invalid repository'; dies_ok { - my $repository = $repo->get_repository(); + my $repository = $repo->get_repository; } 'throws exception for no repository'; dies_ok { - my $repository = $repo->get_repository('../../../'); + my $repository = $get_repo_from_native_name->( '../../../' ); } 'Relative directory not contained within repo_dir'; -my $repository = $repo->get_repository( "repo1" ); +my $repository = $get_repo_from_native_name->( "repo1" ); +isa_ok($repository, 'Gitalist::Git::Repository'); + +$repository = $get_repo_from_native_name->( "recursive/goingdeeper/scratch.git" ); +isa_ok($repository, 'Gitalist::Git::Repository'); +cmp_ok($repository->description, 'eq', 'goingdeeper/scratch.git repo', 'Got the right repo'); + +$repository = $get_repo_from_native_name->( "recursive/goingdeeper2/scratch.git" ); isa_ok($repository, 'Gitalist::Git::Repository'); +cmp_ok($repository->description, 'eq', 'goingdeeper2/scratch.git repo', 'Got the right repo'); + # check for bug where get_repository blew up if repo_dir # was a relative path lives_ok { my $repo2_dir = "$Bin/lib/../lib/repositories"; my $repo2 = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo2_dir ); - my $repo2_proj = $repo2->get_repository("repo1"); -} 'relative repo_dir properly handled'; -#A test ignoring git repos within git directories -# test will ignor the fake repos under the t/ directory -$repo_dir = Path::Class::Dir->new("$Bin/../../")->absolute; -$repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $repo_dir ); -isa_ok($repo, 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive'); -is( $repo->repo_dir, $repo_dir, "repo->repo_dir is correct" ); -$repository_list = $repo->repositories; -is( scalar @{$repository_list}, 1, '->repositories is an array with the correct number of members' ); -is( $repository_list->[0]->{name}, 'Gitalist', 'repository correctly loaded' ); + my $repo2_proj = $repo2->get_repository( dir( "repo1" )->stringify ); +} 'relative repo_dir properly handled';