3 # Copyright (c) 2009 Mark Rada
 
   6 test_description='gitweb as standalone script (http status tests).
 
   8 This test runs gitweb (git web interface) as a CGI script from the
 
   9 commandline, and checks that it returns the expected HTTP status
 
  16 # Gitweb only provides the functionality tested by the 'modification times'
 
  17 # tests if it can access a date parser from one of these modules:
 
  19 perl -MHTTP::Date -e 0 >/dev/null 2>&1 && test_set_prereq DATE_PARSER
 
  20 perl -MTime::ParseDate -e 0 >/dev/null 2>&1 && test_set_prereq DATE_PARSER
 
  22 # ----------------------------------------------------------------------
 
  25 test_expect_success 'setup' "
 
  26         test_commit 'SnapshotTests' 'i can has snapshot'
 
  30 cat >>gitweb_config.perl <<\EOF
 
  31 $feature{'snapshot'}{'override'} = 0;
 
  35     'snapshots: tgz only default format enabled' \
 
  36     'gitweb_run "p=.git;a=snapshot;h=HEAD;sf=tgz" &&
 
  37     grep "Status: 200 OK" gitweb.output &&
 
  38     gitweb_run "p=.git;a=snapshot;h=HEAD;sf=tbz2" &&
 
  39     grep "403 - Unsupported snapshot format" gitweb.output &&
 
  40     gitweb_run "p=.git;a=snapshot;h=HEAD;sf=txz" &&
 
  41     grep "403 - Snapshot format not allowed" gitweb.output &&
 
  42     gitweb_run "p=.git;a=snapshot;h=HEAD;sf=zip" &&
 
  43     grep "403 - Unsupported snapshot format" gitweb.output'
 
  46 cat >>gitweb_config.perl <<\EOF
 
  47 $feature{'snapshot'}{'default'} = ['tgz','tbz2','txz','zip'];
 
  51     'snapshots: all enabled in default, use default disabled value' \
 
  52     'gitweb_run "p=.git;a=snapshot;h=HEAD;sf=tgz" &&
 
  53     grep "Status: 200 OK" gitweb.output &&
 
  54     gitweb_run "p=.git;a=snapshot;h=HEAD;sf=tbz2" &&
 
  55     grep "Status: 200 OK" gitweb.output &&
 
  56     gitweb_run "p=.git;a=snapshot;h=HEAD;sf=txz" &&
 
  57     grep "403 - Snapshot format not allowed" gitweb.output &&
 
  58     gitweb_run "p=.git;a=snapshot;h=HEAD;sf=zip" &&
 
  59     grep "Status: 200 OK" gitweb.output'
 
  62 cat >>gitweb_config.perl <<\EOF
 
  63 $known_snapshot_formats{'zip'}{'disabled'} = 1;
 
  67     'snapshots: zip explicitly disabled' \
 
  68     'gitweb_run "p=.git;a=snapshot;h=HEAD;sf=zip" &&
 
  69     grep "403 - Snapshot format not allowed" gitweb.output'
 
  70 test_debug 'cat gitweb.output'
 
  73 cat >>gitweb_config.perl <<\EOF
 
  74 $known_snapshot_formats{'tgz'}{'disabled'} = 0;
 
  78     'snapshots: tgz explicitly enabled' \
 
  79     'gitweb_run "p=.git;a=snapshot;h=HEAD;sf=tgz" &&
 
  80     grep "Status: 200 OK" gitweb.output'
 
  81 test_debug 'cat gitweb.headers'
 
  84 # ----------------------------------------------------------------------
 
  87 test_expect_success 'snapshots: good tree-ish id' '
 
  88         gitweb_run "p=.git;a=snapshot;h=master;sf=tgz" &&
 
  89         grep "Status: 200 OK" gitweb.output
 
  91 test_debug 'cat gitweb.headers'
 
  93 test_expect_success 'snapshots: bad tree-ish id' '
 
  94         gitweb_run "p=.git;a=snapshot;h=frizzumFrazzum;sf=tgz" &&
 
  95         grep "404 - Object does not exist" gitweb.output
 
  97 test_debug 'cat gitweb.output'
 
  99 test_expect_success 'snapshots: bad tree-ish id (tagged object)' '
 
 100         echo object > tag-object &&
 
 101         git add tag-object &&
 
 102         test_tick && git commit -m "Object to be tagged" &&
 
 103         git tag tagged-object $(git hash-object tag-object) &&
 
 104         gitweb_run "p=.git;a=snapshot;h=tagged-object;sf=tgz" &&
 
 105         grep "400 - Object is not a tree-ish" gitweb.output
 
 107 test_debug 'cat gitweb.output'
 
 109 test_expect_success 'snapshots: good object id' '
 
 110         ID=$(git rev-parse --verify HEAD) &&
 
 111         gitweb_run "p=.git;a=snapshot;h=$ID;sf=tgz" &&
 
 112         grep "Status: 200 OK" gitweb.output
 
 114 test_debug 'cat gitweb.headers'
 
 116 test_expect_success 'snapshots: bad object id' '
 
 117         gitweb_run "p=.git;a=snapshot;h=abcdef01234;sf=tgz" &&
 
 118         grep "404 - Object does not exist" gitweb.output
 
 120 test_debug 'cat gitweb.output'
 
 122 # ----------------------------------------------------------------------
 
 123 # modification times (Last-Modified and If-Modified-Since)
 
 125 test_expect_success DATE_PARSER 'modification: feed last-modified' '
 
 126         gitweb_run "p=.git;a=atom;h=master" &&
 
 127         grep "Status: 200 OK" gitweb.headers &&
 
 128         grep "Last-modified: Thu, 7 Apr 2005 22:14:13 +0000" gitweb.headers
 
 130 test_debug 'cat gitweb.headers'
 
 132 test_expect_success DATE_PARSER 'modification: feed if-modified-since (modified)' '
 
 133         HTTP_IF_MODIFIED_SINCE="Wed, 6 Apr 2005 22:14:13 +0000" &&
 
 134         export HTTP_IF_MODIFIED_SINCE &&
 
 135         test_when_finished "unset HTTP_IF_MODIFIED_SINCE" &&
 
 136         gitweb_run "p=.git;a=atom;h=master" &&
 
 137         grep "Status: 200 OK" gitweb.headers
 
 139 test_debug 'cat gitweb.headers'
 
 141 test_expect_success DATE_PARSER 'modification: feed if-modified-since (unmodified)' '
 
 142         HTTP_IF_MODIFIED_SINCE="Thu, 7 Apr 2005 22:14:13 +0000" &&
 
 143         export HTTP_IF_MODIFIED_SINCE &&
 
 144         test_when_finished "unset HTTP_IF_MODIFIED_SINCE" &&
 
 145         gitweb_run "p=.git;a=atom;h=master" &&
 
 146         grep "Status: 304 Not Modified" gitweb.headers
 
 148 test_debug 'cat gitweb.headers'
 
 150 test_expect_success DATE_PARSER 'modification: snapshot last-modified' '
 
 151         gitweb_run "p=.git;a=snapshot;h=master;sf=tgz" &&
 
 152         grep "Status: 200 OK" gitweb.headers &&
 
 153         grep "Last-modified: Thu, 7 Apr 2005 22:14:13 +0000" gitweb.headers
 
 155 test_debug 'cat gitweb.headers'
 
 157 test_expect_success DATE_PARSER 'modification: snapshot if-modified-since (modified)' '
 
 158         HTTP_IF_MODIFIED_SINCE="Wed, 6 Apr 2005 22:14:13 +0000" &&
 
 159         export HTTP_IF_MODIFIED_SINCE &&
 
 160         test_when_finished "unset HTTP_IF_MODIFIED_SINCE" &&
 
 161         gitweb_run "p=.git;a=snapshot;h=master;sf=tgz" &&
 
 162         grep "Status: 200 OK" gitweb.headers
 
 164 test_debug 'cat gitweb.headers'
 
 166 test_expect_success DATE_PARSER 'modification: snapshot if-modified-since (unmodified)' '
 
 167         HTTP_IF_MODIFIED_SINCE="Thu, 7 Apr 2005 22:14:13 +0000" &&
 
 168         export HTTP_IF_MODIFIED_SINCE &&
 
 169         test_when_finished "unset HTTP_IF_MODIFIED_SINCE" &&
 
 170         gitweb_run "p=.git;a=snapshot;h=master;sf=tgz" &&
 
 171         grep "Status: 304 Not Modified" gitweb.headers
 
 173 test_debug 'cat gitweb.headers'
 
 175 test_expect_success DATE_PARSER 'modification: tree snapshot' '
 
 176         ID=$(git rev-parse --verify HEAD^{tree}) &&
 
 177         HTTP_IF_MODIFIED_SINCE="Wed, 6 Apr 2005 22:14:13 +0000" &&
 
 178         export HTTP_IF_MODIFIED_SINCE &&
 
 179         test_when_finished "unset HTTP_IF_MODIFIED_SINCE" &&
 
 180         gitweb_run "p=.git;a=snapshot;h=$ID;sf=tgz" &&
 
 181         grep "Status: 200 OK" gitweb.headers &&
 
 182         ! grep -i "last-modified" gitweb.headers
 
 184 test_debug 'cat gitweb.headers'
 
 186 # ----------------------------------------------------------------------
 
 189 # always hit the load limit
 
 190 cat >>gitweb_config.perl <<\EOF
 
 194 test_expect_success 'load checking: load too high (default action)' '
 
 195         gitweb_run "p=.git" &&
 
 196         grep "Status: 503 Service Unavailable" gitweb.headers &&
 
 197         grep "503 - The load average on the server is too high" gitweb.body
 
 199 test_debug 'cat gitweb.headers'
 
 201 # turn off load checking
 
 202 cat >>gitweb_config.perl <<\EOF
 
 203 our $maxload = undef;
 
 207 # ----------------------------------------------------------------------
 
 210 test_expect_success 'invalid arguments: invalid regexp (in project search)' '
 
 211         gitweb_run "a=project_list;s=*\.git;sr=1" &&
 
 212         grep "Status: 400" gitweb.headers &&
 
 213         grep "400 - Invalid.*regexp" gitweb.body
 
 215 test_debug 'cat gitweb.headers'