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