use FindBin qw/$Bin/;
BEGIN {
- my $env = "$FindBin::Bin/script/env";
+ my $env = "$FindBin::Bin/../script/env";
if (-r $env) {
do $env or die $@;
}
use warnings;
use Test::More qw/no_plan/;
use Test::Exception;
-
-use Data::Dumper;
+use Path::Class::Dir;
BEGIN { use_ok 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive' }
is_deeply( \@sorted_names, [ qw( bare.git barerecursive.git nodescription repo1 scratch.git) ], 'Repositories are correctly loaded' );
dies_ok {
- my $repository = $repo->get_repository("$repo_dir/NoSuchRepository");
+ my $repository = $repo->get_repository("NoSuchRepository");
} 'throws exception for invalid repository';
dies_ok {
my $repository = $repo->get_repository('../../../');
} 'Relative directory not contained within repo_dir';
-my $repository = $repo->get_repository( "$repo_dir/repo1" );
+my $repository = $repo->get_repository( "repo1" );
+isa_ok($repository, 'Gitalist::Git::Repository');
+
+$repository = $repo->get_repository( "scratch.git" );
isa_ok($repository, 'Gitalist::Git::Repository');
# check for bug where get_repository blew up if repo_dir
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("$repo2_dir/repo1");
+ 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' );