Remove XML::Atom - unused here
[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
82bc0f05 29my $repository_list = $repo->repositories;
30ok(scalar @{$repository_list} == 3, '->repositories is an array with the correct number of members' );
31isa_ok($repository_list->[0], 'Gitalist::Git::Repository');
32is($repository_list->[0]->{name}, 'bare.git', '->repositories has correct name for "bare.git" repo' );
ba033c36 33
3bbb1202 34dies_ok {
82bc0f05 35 my $repository = $repo->get_repository('NoSuchRepository');
36} 'throws exception for invalid repository';
3bbb1202 37
38dies_ok {
82bc0f05 39 my $repository = $repo->get_repository();
40} 'throws exception for no repository';
3bbb1202 41
5232dbdd 42dies_ok {
82bc0f05 43 my $repository = $repo->get_repository('../../../');
5232dbdd 44} 'throws exception for directory traversal';
45
82bc0f05 46my $repository = $repo->get_repository('repo1');
47isa_ok($repository, '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';