#!/usr/bin/env perl
-use strict;
-use warnings;
-use Test::More qw/no_plan/;
-
-BEGIN { use_ok 'Catalyst::Test', 'Gitalist' }
-
-# Full tests are only run if the APP_TEST env var is set.
-# This is needed to load the test configuration.
-diag("*** SKIPPING app tests.
-*** Set APP_TEST for the tests to run fully") if !$ENV{APP_TEST};
-SKIP: {
- skip "Set APP_TEST for the tests to run fully",
- 1 if !$ENV{APP_TEST};
-
- ok( request('/')->is_success, 'Request should succeed' );
+use FindBin qw/$Bin/;
+use lib "$Bin/lib";
+use TestGitalist;
+
+for my $p ('', qw{
+ repo1 nodescription bare.git opml search
+ fragment/collectionofrepositories
+}) {
+ my $path = '/' . $p;
+ ok( request($path)->is_success, "$path should succeed");
+}
+my $response = request('/DoesNotExist');
+is $response->code, 404, 'invalid repository 404s';
+like $response->content, qr/Page not found/, 'invalid repository handled correctly';
+
+# URI tests for repo1
+foreach my $test (map {curry_test_uri($_)} ('fragment/repo1', 'repo1') ) {
+ $test->('');
+ $test->('shortlog');
+ $test->('log');
+ $test->('heads');
+ $test->('tags');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/tree');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/tree/dir1');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/diff');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/diff/plain');
+ #test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/shortlog/dir1');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/history/dir1');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/blame/file1');
+ $test->('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/blob/file1');
+}
+{
# URI tests for repo1
- use Data::Dumper;
- my $test_repo1 = curry_test_uri('repo1');
- &$test_repo1('/summary');
- &$test_repo1('/heads');
- &$test_repo1('/shortlog');
- &$test_repo1('/log');
- &$test_repo1('/commit');
- &$test_repo1('/commitdiff');
- &$test_repo1('/tree');
-
- # legacy URIs
- &$test_repo1('/', 'a=summary');
- &$test_repo1('/', 'a=heads');
- &$test_repo1('/', 'a=shortlog');
- &$test_repo1('/', 'a=log');
- &$test_repo1('/', 'a=commit');
- &$test_repo1('/', 'a=commitdiff');
- &$test_repo1('/', 'a=tree');
-# &$test_repo1('/', 'a=blob;f=file1');
-
-} # Close APP_TEST skip
-
-sub test_uri {
- my ($p, $uri, $qs) = @_;
- $qs ||= '';
- my $request = "$uri?p=repo1;$qs";
- warn("request: $request");
- my $response = request($request);
- ok($response->is_success, "ok $p - $uri");
+ local *test = curry_test_uri('repo1');
+ test('search');
+ test('reflog');
+
+ test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/patch');
+ test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/patches/1');
+ test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/patches/2');
+ test('36c6c6708b8360d7023e8a1649c45bcf9b3bd818/raw/file1');
+
+ TODO: {
+ local $TODO = "FIXME";
+ test('search', 'type=commit&text=added');
+
+ # 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');
+ }
}
-sub curry_test_uri {
- my $p = shift;
- sub {
- my ($uri, $qs) = @_;
- test_uri($p, $uri, $qs);
- };
-};
+done_testing;