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