X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F01app.t;h=57dba804242ab0d50940453261190a5d58e8737d;hb=a349e797ad4ea6be7d0748281b749c6a2b3b83c4;hp=a39a12862bcd4531af6cc3c2fcc1ea19003d3923;hpb=b443902266ce358a690fa9deb28696d80db173c1;p=catagits%2FGitalist.git diff --git a/t/01app.t b/t/01app.t index a39a128..57dba80 100644 --- a/t/01app.t +++ b/t/01app.t @@ -6,57 +6,66 @@ use FindBin qw/$Bin/; BEGIN { $ENV{GITALIST_CONFIG} = $Bin; - use_ok 'Catalyst::Test', 'Gitalist' + $ENV{GITALIST_REPO_DIR} = ''; + use_ok 'Catalyst::Test', 'Gitalist'; } -ok( request('/')->is_success, 'Request should succeed' ); - -for my $p (qw/ repo1 nodescription /) { - my $path = '/summary?p=' . $p; +for my $p ('', qw/ repo1 nodescription bare.git opml /) { + my $path = '/' . $p; ok( request($path)->is_success, "$path should succeed"); } -my $response = request('/summary?p=DoesNotExist'); -is $response->code, 404, 'invalid project 404s'; -like $response->content, qr/Page not found/, 'invalid project handled correctly'; +my $response = request('/DoesNotExist'); +is $response->code, 404, 'invalid repository 404s'; +like $response->content, qr/Page not found/, 'invalid repository handled correctly'; -is request('/summary?p=../../../')->code, 404, 'directory traversal failed'; { # URI tests for repo1 local *test = curry_test_uri('repo1'); - test('/summary'); - test('/shortlog'); - test('/log'); - test('/reflog'); - test('/commit'); - test('/commitdiff', 'h=36c6c6708b8360d7023e8a1649c45bcf9b3bd818'); - test('/tree', 'h=145dc3ef5d307be84cb9b325d70bd08aeed0eceb;hb=36c6c6708b8360d7023e8a1649c45bcf9b3bd818'); - test('/search', 'h=36c6c6708b8360d7023e8a1649c45bcf9b3bd818&f=&type=commit&text=added'); - test('/blobdiff', 'f=file1;h=5716ca5987cbf97d6bb54920bea6adde242d87e6;hp=257cc5642cb1a054f08cc83f2d943e56fd3ebe99;hb=refs/heads/master;hpb=3bc0634310b9c62222bb0e724c11ffdfb297b4ac'); - test('/blob', 'f=dir1/file2;hb=36c6c6708b8360d7023e8a1649c45bcf9b3bd818'); - test('/patch'); - test('/patch', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e'); - test('/patch', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e;hp=3bc0634310b9c62222bb0e724c11ffdfb297b4ac'); - test('/patches'); - test('/patches', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e'); - test('/patches', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e;hp=3bc0634310b9c62222bb0e724c11ffdfb297b4ac'); + test(''); + test('shortlog'); + test('log'); + test('reflog'); + test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818'); + test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/tree'); + test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/diff'); + test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/patch'); + test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/patches/1'); + test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/patches/2'); + + TODO: { + local $TODO = "FIXME"; + test('search', 'type=commit&text=added'); + + + test('blob', 'f=dir1/file2;hb=36c6c6708b8360d7023e8a1649c45bcf9b3bd818'); + + # FIXME - What's the difference here? + #test('patch', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e'); + #test('patch', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e;hp=3bc0634310b9c62222bb0e724c11ffdfb297b4ac'); + #test('patches', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e'); + #test('patches', 'h=3f7567c7bdf7e7ebf410926493b92d398333116e;hp=3bc0634310b9c62222bb0e724c11ffdfb297b4ac'); + } } done_testing; sub test_uri { - my ($p, $uri, $qs) = @_; + my ($uri, $qs) = @_; $qs ||= ''; - my $request = "$uri?p=repo1;$qs"; + my $request = "/$uri"; + $request .= "?$qs" if defined $qs; my $response = request($request); - ok($response->is_success, "ok $p - $uri - $qs"); + ok($response->is_success, "ok $uri - $qs"); + return $response; } sub curry_test_uri { - my $p = shift; + my $prefix = shift; + my $to_curry = shift || \&test_uri; sub { - my ($uri, $qs) = @_; - test_uri($p, $uri, $qs); + my $uri = shift; + $to_curry->("$prefix/$uri", @_); }; -}; +}